青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 43,  comments - 9,  trackbacks - 0
grids 3741 Escape
http://poj.grids.cn/problem?id=3741
此題我用組合數(shù)學過的. 歡迎交流各種方法.

原題意: 從(0,0)開始,初始面向y軸正方向,只能右轉或直走,每個格子至多經(jīng)過1次,到達(x,y),求有多少種走法

轉化為: 從(x,y)開始,初始朝向任意,只能左轉或直走,!@#%^$#$^^$@%,到達(0,0)的走法數(shù)
總的走法數(shù)即為初始朝向分別為上下左右的走法數(shù)之和.

觀察符合要求的路徑,其肯定是螺旋形的,也就是各邊不相交.
所以可以分別設 (x,y)上方橫線數(shù)up, 下方橫線數(shù)down, 左側豎線數(shù)left, 右側豎線數(shù)right
按初始朝向分4種情況,可以找出up,down,left,right之間的數(shù)量關系! 可以自己畫一下,很容易發(fā)現(xiàn).

以初始朝向左為例,求 S左:
left-1 = up = right = down (令其 = k)
這樣對某個k ,走法數(shù)即為在4個方位取出對應數(shù)量線段的方法數(shù).
設(x,y)到地圖4個邊界的距離分別為 dl, du, dr, dd
則 Sk = C(left-1, dl-1) * C(up, du) * C(right, dr) * C(down, dd)
其中l(wèi)eft項的上下標都減了1,是因為左側豎線肯定有一條是y軸,所以只選出剩下的left-1條

枚舉所有不會越界的 k ,即保證 C(k, n) 中 k<=n, 就求得這個方向方法數(shù)之和

最后把4個方向的S加起來即可

注意一些特殊情況:
1. (x,y)在 y 軸上時,直接輸出1
2. 初始方向為下的情況,枚舉k要從1開始,也就是至少要繞一圈. 因為 !%!@^$#$@#$ :)

ps.
初始朝向 上: left-1 = up-1 = right = down
初始朝向 右: left-1 = up-1 = right-1 = down
初始朝向 下: left = up = right = down

代碼:

 1 #include <cstdio>
 2 #include <cstdlib>
 3 #include <cstring>
 4 #include <algorithm>
 5 using namespace std;
 6 
 7 const __int64 MOD = 100000007;
 8 __int64 x,y,X,Y,c[2100][2100];
 9 __int64 ans,tmp;
10 int dk[4][4= {//lurd
11     1,0,0,0//left
12     1,1,0,0//up
13     1,1,1,0//right
14     1,1,1,1  //down
15 };
16 int N;
17 
18 __int64 func(__int64 n, __int64 k){
19     if(n<k) return 0;
20     if(c[n][k]<0)
21         c[n][k] = (func(n-1, k-1+ func(n-1, k)) % MOD;
22     return c[n][k];
23 }
24 
25 inline int mi4(int x1, int x2, int x3, int x4){
26     return min(min(x1,x2),min(x3,x4));
27 }
28 
29 int main(){
30     int i,j,k,z;
31     int left,right,up,down;
32     memset(c, 0xffsizeof(c));
33     c[0][0= 1;
34     for(i=1; i<=2000; i++){
35         c[i][0= 1;
36         c[i][1= i;
37         c[i][i] = 1;
38     }
39     scanf("%d",&N);
40     while(N--){
41         scanf("%I64d %I64d %I64d %I64d",&X, &Y, &x, &y);
42         left = x; right = X-x;
43         up = Y-y; down = y;
44         if(x == 0){
45             printf("1\n");
46             continue;
47         }
48         ans = 0;
49         for(i=0; i<4; i++){
50             z = mi4(left-dk[i][0], up-dk[i][1], right-dk[i][2], down-dk[i][3]);
51             for(k=0; k<=z; k++){
52                 tmp = func(left-1, k+dk[i][0]-1% MOD;
53                 tmp = (tmp * func(up, k+dk[i][1])) % MOD;
54                 tmp = (tmp * func(right, k+dk[i][2])) % MOD;
55                 tmp = (tmp * func(down, k+dk[i][3])) % MOD;
56                 ans = (ans + tmp) % MOD;
57             }
58         }
59         printf("%I64d\n",ans);
60     }
61     return 0;
62 }
63 


posted on 2009-05-18 18:33 wolf5x 閱讀(335) 評論(0)  編輯 收藏 引用 所屬分類: acm_icpc
<2009年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

"Do not spend all your time on training or studying - this way you will probably become very exhausted and unwilling to compete more. Whatever you do - have fun. Once you find programming is no fun anymore – drop it. Play soccer, find a girlfriend, study something not related to programming, just live a life - programming contests are only programming contests, and nothing more. Don't let them become your life - for your life is much more interesting and colorful." -- Petr

留言簿(3)

隨筆分類(59)

隨筆檔案(43)

cows

搜索

  •  

最新評論

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美日韩中文字幕综合视频| 欧美成人蜜桃| 亚洲一区二区三区视频播放| 亚洲手机视频| 国产欧美日本| 欧美亚洲色图校园春色| 美女黄色成人网| 日韩一级免费观看| 国产精品日韩欧美一区二区三区| 欧美在线日韩| 亚洲精品国产系列| 欧美日韩理论| 午夜欧美不卡精品aaaaa| 狂野欧美一区| 午夜精品久久| 在线看欧美日韩| 欧美吻胸吃奶大尺度电影| 久久精品视频在线播放| 亚洲手机视频| 亚洲盗摄视频| 久久不射网站| 一本色道久久综合狠狠躁篇怎么玩 | 亚洲欧洲日本国产| 欧美日韩在线视频首页| 国产精品无码专区在线观看| 韩国亚洲精品| 国产精品日本欧美一区二区三区| 国外成人在线| 亚洲无玛一区| 一区二区激情视频| 亚洲国产专区| 亚洲国产精品t66y| 国产一区视频在线观看免费| 欧美亚男人的天堂| 一区二区三区中文在线观看| 国产精品香蕉在线观看| 在线观看一区二区精品视频| 亚洲一区二区三区在线| 免费观看成人鲁鲁鲁鲁鲁视频 | 一本到高清视频免费精品| 久久久久久久尹人综合网亚洲 | 亚洲美女尤物影院| 嫩模写真一区二区三区三州| 久久免费视频这里只有精品| 久久国产综合精品| 久久激情网站| 99天天综合性| 在线视频中文亚洲| 亚洲一区二区三区高清不卡| 欧美ed2k| 欧美极品在线视频| 免费久久99精品国产| 国产美女一区二区| 精品盗摄一区二区三区| 亚洲欧洲av一区二区三区久久| 亚洲成人在线视频播放 | 久久爱www久久做| 久久av红桃一区二区小说| 欧美系列一区| 一区电影在线观看| 亚洲国产中文字幕在线观看| 亚洲精品1区2区| 亚洲欧洲日本在线| 蜜臀99久久精品久久久久久软件| 久久综合久久久久88| 蜜臀久久99精品久久久久久9| 久久se精品一区精品二区| 国产精品黄页免费高清在线观看| 国产情人节一区| 午夜在线不卡| 欧美大色视频| 久久亚洲一区二区三区四区| 欧美美女bb生活片| 国产日韩精品在线观看| 亚洲国产精品一区二区第一页 | 亚洲一区999| 国产精品久久久久久av下载红粉| 亚洲一区激情| 男人的天堂成人在线| 久久久久久色| 国产精品国产三级国产普通话蜜臀 | 久久精品官网| 一区二区亚洲欧洲国产日韩| 免费欧美日韩| 欧美久久电影| 午夜久久美女| 久久夜色精品国产欧美乱极品| 亚洲精品三级| 久久综合九色综合欧美狠狠| 亚洲精品中文字幕有码专区| 久久精品国产99| 亚洲人成在线免费观看| 中文久久精品| 1000部精品久久久久久久久 | 欧美一区二区三区视频免费播放| 狠狠爱www人成狠狠爱综合网| 亚洲国产欧美不卡在线观看 | 亚洲精品婷婷| 亚洲一区二区不卡免费| 亚洲国产高清自拍| 亚洲影视在线播放| 亚洲精品一区二区三区av| 亚洲男人的天堂在线观看| 欧美日韩国语| 亚洲乱码国产乱码精品精天堂 | 亚洲激情成人在线| 中日韩男男gay无套| 亚洲成人在线网| 亚洲特级毛片| av成人国产| 麻豆精品传媒视频| 久久精品中文字幕一区二区三区| 欧美激情一区二区在线| 久久天天躁狠狠躁夜夜爽蜜月| 欧美国产一区二区| 久久亚洲影音av资源网| 亚洲一级黄色| 欧美黄色一区二区| 中文在线一区| 欧美粗暴jizz性欧美20| 99伊人成综合| 久久久久久9| 欧美一级在线播放| 在线亚洲一区观看| 亚洲国产成人久久综合一区| 亚洲欧美日韩中文在线制服| 国产精品久久久久国产a级| 亚洲国产日韩在线| 亚洲电影在线免费观看| 久久精品一区二区国产| 久久久久99| 国产一区在线免费观看| 亚洲欧美一区二区三区久久 | 久久精品视频播放| 久久精品二区亚洲w码| 国产精品久久久久一区二区| 欧美一区二区三区久久精品茉莉花 | 国产一区久久| 午夜精品电影| 久久精品一区二区| 国产一区二区精品| 亚洲国产精品第一区二区三区| 一区视频在线| 久久精品国产免费| 久久嫩草精品久久久精品| 国产亚洲人成网站在线观看| 性欧美xxxx大乳国产app| 久久精品系列| 伊人久久婷婷色综合98网| 日韩视频专区| 亚洲永久精品大片| 国产精品久久久久久久第一福利| 亚洲伊人伊色伊影伊综合网| 欧美在线视频播放| 一区二区三区在线高清| 欧美电影免费观看高清完整版| 亚洲精品免费在线播放| 欧美一进一出视频| 亚洲国产精品第一区二区| 欧美精品一区二| 亚洲欧美日韩国产精品| 久久一区二区三区四区| 亚洲免费观看视频| 国产精品色婷婷| 久久综合色天天久久综合图片| 亚洲精品乱码久久久久久黑人| 午夜精品成人在线视频| 在线观看亚洲| 欧美午夜一区二区三区免费大片 | 国产毛片精品国产一区二区三区| 欧美一区二区三区视频免费播放| 亚洲第一网站| 欧美自拍偷拍午夜视频| 亚洲美女精品一区| 国产一区二区三区在线观看免费视频 | 亚洲一区观看| 在线观看日韩av先锋影音电影院 | 在线免费不卡视频| 欧美精品久久久久久久久老牛影院| 亚洲午夜精品| 亚洲高清在线视频| 欧美一区二区免费观在线| 亚洲精品资源| 国内不卡一区二区三区| 欧美日韩一区二区免费在线观看 | 国产精品午夜电影| 欧美国产激情| 久久精品视频在线| 亚洲一区久久| 日韩午夜高潮| 亚洲国产精品女人久久久| 久久精品一区二区三区四区| 亚洲视频一区在线观看| 亚洲欧洲一区二区三区| 精品1区2区3区4区| 国产亚洲综合在线| 国产精品一区在线播放| 欧美午夜精彩| 欧美日韩国产探花| 欧美大片第1页|