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

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

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

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

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

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

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

最后把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
<2011年7月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

"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>
            久久噜噜噜精品国产亚洲综合| 欧美中文字幕视频| 国产欧美 在线欧美| 欧美日韩国产bt| 亚洲淫片在线视频| 欧美激情视频一区二区三区免费| 9人人澡人人爽人人精品| 免费观看亚洲视频大全| 亚洲一区国产| 亚洲视频精品| 日韩亚洲视频在线| 欧美大胆成人| 久久在线视频在线| 一区二区三区在线视频免费观看| 亚洲欧美日韩精品久久| 一区二区精品在线观看| 欧美日精品一区视频| 一区二区三区精品视频| 99视频在线观看一区三区| 欧美日韩一区二区欧美激情| 亚洲视频二区| 亚洲免费视频一区二区| 国产欧美精品国产国产专区| 久久gogo国模裸体人体| 久久狠狠久久综合桃花| 亚洲国产欧美日韩| 亚洲精品一区中文| 国产精品欧美一区二区三区奶水| 欧美亚洲自偷自偷| 久久精品国产亚洲一区二区三区| 亚洲成色777777女色窝| 亚洲精品久久久久久下一站 | 欧美日韩国产一中文字不卡| 亚洲精品日韩综合观看成人91| 亚洲黄色片网站| 欧美日韩在线免费视频| 欧美淫片网站| 美女精品国产| 亚洲午夜精品| 欧美一区二区国产| 久久精品亚洲| 在线播放国产一区中文字幕剧情欧美| 久久久成人精品| 伊人天天综合| 韩日在线一区| 国产精品久久一级| 亚洲免费在线电影| 欧美成年人在线观看| 久久不射网站| 久久综合狠狠综合久久综青草 | 最新亚洲电影| 欧美午夜大胆人体| 美女亚洲精品| 国产精品乱人伦中文| 欧美xart系列高清| 国产精品乱码久久久久久| 蜜桃av久久久亚洲精品| 欧美日韩一视频区二区| 裸体女人亚洲精品一区| 国产精品国产三级国产普通话蜜臀 | 一区二区三区福利| 久久国产欧美精品| 亚洲一区二区三区在线看| 久久精品免费播放| 亚洲一区免费观看| 牛夜精品久久久久久久99黑人 | 麻豆国产精品777777在线| 欧美精品在线一区二区三区| 久久国产婷婷国产香蕉| 欧美日韩午夜精品| 欧美激情aaaa| 在线观看不卡av| 性欧美xxxx大乳国产app| 亚洲一区在线观看视频| 欧美成人午夜视频| 免费在线视频一区| 国内精品福利| 亚洲欧美伊人| 一区二区日本视频| 韩国精品在线观看| 欧美一区二区三区男人的天堂| 亚洲欧洲综合| 久久精品女人| 国产精品久久久久久久浪潮网站 | 国产欧美日韩亚洲| 欧美一区二区在线| 久色成人在线| 久久免费视频在线观看| 国产欧美一区二区三区在线看蜜臀| 亚洲黄色在线看| 久久九九99| 欧美在线首页| 国产午夜久久久久| 性高湖久久久久久久久| 午夜久久久久久久久久一区二区| 欧美日韩一区二区国产| 日韩视频在线永久播放| 在线亚洲精品| 欧美午夜精品久久久久免费视| 亚洲精品日韩综合观看成人91| 一本色道久久综合狠狠躁的推荐| 欧美大片一区二区三区| 亚洲韩国青草视频| 99精品欧美一区二区蜜桃免费| 欧美精品xxxxbbbb| 99re成人精品视频| 亚洲欧美成人一区二区在线电影| 国产精品成人午夜| 亚洲欧美日韩国产中文在线| 欧美诱惑福利视频| 激情成人亚洲| 免费短视频成人日韩| 亚洲精品一区在线观看香蕉| 亚洲欧美日韩一区二区三区在线 | 亚洲国产日韩欧美在线99| 免费欧美电影| 一区二区日韩伦理片| 欧美一区二区三区免费在线看| 国产欧美日韩免费看aⅴ视频| 欧美在线视频日韩| 亚洲大片精品永久免费| 亚洲色图自拍| 国产亚洲欧美一区二区| 久久综合国产精品台湾中文娱乐网| 亚洲精品久久久久久久久久久久久| 久久久久国产成人精品亚洲午夜| 韩日欧美一区二区| 亚洲午夜电影| 免费不卡在线观看| 欧美乱在线观看| 欧美激情亚洲一区| 亚洲国产欧美一区二区三区丁香婷| 午夜国产精品影院在线观看| 国产精品地址| 亚洲小说春色综合另类电影| 欧美一区二区国产| 欧美日本二区| 一区二区三区免费看| 国产精一区二区三区| 久久青草久久| 99国产一区| 免费成人黄色片| 亚洲一二三区在线观看| 国内精品亚洲| 欧美日韩国产在线观看| 久久精品在线观看| 宅男66日本亚洲欧美视频| 美女精品一区| 久久av一区二区三区漫画| 日韩视频一区二区| 国产一区日韩一区| 国产精品国产三级国产普通话蜜臀| 久久野战av| 午夜视频久久久| 亚洲婷婷国产精品电影人久久| 久久久精彩视频| 免费一级欧美片在线播放| 亚洲男人第一网站| 国产一区在线播放| 欧美性猛交xxxx乱大交退制版| 久久久久久久久久久成人| 久久久久久网址| 免费在线成人av| 欧美特黄视频| 欧美日韩另类丝袜其他| 亚洲激情欧美激情| 久久男人资源视频| 欧美一区二区在线观看| 亚洲图片激情小说| 99亚洲一区二区| 最新中文字幕一区二区三区| 国产综合欧美| 国产亚洲成av人片在线观看桃 | 欧美xx69| 中文一区字幕| 国产日韩欧美不卡| 久久国产精品高清| 日韩一区二区精品视频| 99视频精品| aaa亚洲精品一二三区| 欧美日韩亚洲一区| 午夜国产精品影院在线观看| 久久精品欧美日韩| 亚洲精品久久久久久久久久久久久 | 另类酷文…触手系列精品集v1小说| 久久亚洲精选| 日韩视频免费大全中文字幕| 国产精品麻豆成人av电影艾秋| 性欧美超级视频| 最新亚洲激情| 久久精品国产99国产精品澳门| 在线精品高清中文字幕| 欧美日韩国产在线播放| 午夜伦欧美伦电影理论片| 亚洲国产精品一区二区第四页av | 91久久精品日日躁夜夜躁国产| 亚洲免费成人av电影| 日韩一区二区电影网| 欧美一区二区三区日韩视频| 国产一区二区三区的电影|