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

隨筆 - 68  文章 - 57  trackbacks - 0
<2009年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(8)

隨筆分類(74)

隨筆檔案(68)

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

【題目大意】
  題目的大意是給定一個由許多六面形邊挨著邊組成的圖形,從中心處開始標號為1,按照一個螺旋的方向標號依次增加。問從一個點到另一個點的最短路徑的長度和數目。

【算法分析】
  感覺滿惡心的一個題目,需要瘋狂的找規律。首先容易看出路徑數是一個組合數,并且每一層都是模六循環的。但是怎樣找到層數(也就是最短路徑長度)呢?最開始想建立坐標系然后利用幾何方法算出來,但是如何無論是笛卡爾坐標系還是極坐標系的建立都是困難的;然后想存圖廣搜,發現空間不夠。后來發現,把圖順時針轉90度,出現了一個很有意思的規律。以原點(數字為1)為中心建立坐標系,不過坐標的選取需要一些技巧。可以看出數字是一層層分布的,取x左邊的點坐標為(-2,0),以后每往左增加一層,橫坐標就變化2。其實和原點縱坐標相同且位于其左邊的點恰好是每一層數字最大的結點!這樣只要確定了這個點,可以按照逆時針的順序依次給這一層的所有點的坐標推出來。這樣,給定一個數字,我們可以根據每一層最大的數字推出這個數的坐標。
  現在有了坐標(可以看成是曼哈頓坐標),就可以推測路徑了。把兩個數字的坐標求差,就可以看成是一個在原點了。坐標和路徑的關系不是很好找,寫了4、5行發現了一個很詭異的規律。先把坐標化成正的,然后發現x >= y的時候就是C( (x + y) / 2, y),否則是C( y, (y - x) / 2)。之后就是高精度了。

題目代碼:
  1 import java.util.*;
  2 import java.math.*;
  3 
  4 class point
  5 {
  6     int x, y;
  7     public point(int x, int y)
  8     {
  9         this.x = x;
 10         this.y = y;
 11     }
 12 }
 13 class Main
 14 {
 15     public static void main(String[] args)
 16     {
 17         Scanner in = new Scanner(System.in);
 18         int a, b, len;
 19         BigInteger ans;
 20         point pa, pb;
 21         
 22         while (in.hasNext())
 23         {
 24             a = in.nextInt();
 25             b = in.nextInt();
 26             if (a == 0 && b == 0)
 27                 break;
 28             pa = GetCoordinate(a);
 29             pb = GetCoordinate(b);
 30             pa.x = pb.x - pa.x;
 31             pa.y = pb.y - pa.y;
 32             pa.x = pa.x < 0 ? -pa.x : pa.x;
 33             pa.y = pa.y < 0 ? -pa.y : pa.y;
 34             if (pa.x >= pa.y)
 35             {
 36                 len = (pa.x + pa.y) / 2;
 37                 ans = C(len, pa.y);
 38             }
 39             else
 40             {
 41                 len = pa.y;
 42                 ans = C(len, (pa.y - pa.x) / 2);
 43             }
 44             System.out.print("There ");
 45             if (ans.compareTo(BigInteger.ONE) == 0)
 46                 System.out.print("is 1 route");
 47             else
 48                 System.out.print("are " + ans + " routes");
 49             System.out.println(" of the shortest length " + len + ".");
 50         }
 51     }
 52     static BigInteger C(int n, int k)
 53     {
 54         BigInteger ret = BigInteger.ONE;
 55         if (k > n - k)
 56             k = n - k;
 57         for (int i = 1; i <= k; i++)
 58         {
 59             ret = ret.multiply(new BigInteger(new String(n - i + 1 + "")));
 60             ret = ret.divide(new BigInteger(new String(i + "")));
 61         }
 62         return ret;
 63     }
 64     static point GetCoordinate(int n)
 65     {
 66         int[][] dir = new int[][]{{1-1}, {20}, {11}, {-11}, {-20}, {-1-1}};
 67         int i = 0, j = 0, k = 0, tx, ty, cnt = 0, delta;
 68         point p = new point(00);
 69         
 70         if (n == 1)
 71             return p;
 72         for (i = 2; i <= 1000; i++)
 73             if ((3 * i * i - 3 * i + 1>= n)
 74                 break;
 75         delta = 3 * i * i - 3 * i + 1 - n;
 76         i--;
 77         tx = -2 * i;
 78         ty = 0;
 79         boolean flag = false;
 80         for (j = 0; j < 6; j++)
 81         {
 82             for (k = 0; k < i; k++)
 83             {
 84                 if (cnt == delta)
 85                 {
 86                     flag = true;
 87                     break;
 88                 }
 89                 cnt++;
 90                 tx += dir[j][0];
 91                 ty += dir[j][1];
 92             }
 93             if (flag)
 94                 break;
 95         }
 96         p.x = tx;
 97         p.y = ty;
 98 
 99         return p;
100     }
101 }
102 



posted on 2009-06-16 22:12 sdfond 閱讀(418) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm - Combinatorics
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            午夜精品久久久久久久久 | 欧美日韩一区二区三区高清| 亚洲精品1234| 亚洲综合电影| 韩国一区电影| 欧美大片免费看| 99视频一区二区三区| 久久精品国产99国产精品澳门| 在线不卡免费欧美| 欧美性片在线观看| 久久天堂av综合合色| 一本色道久久综合狠狠躁篇怎么玩| 亚洲欧美国产精品桃花| 亚洲欧美日韩精品一区二区 | 欧美日韩一区三区四区| 性刺激综合网| 亚洲欧洲一区二区在线播放| 欧美在线观看网址综合| 亚洲日韩第九十九页| 国产伦精品一区二区三区视频孕妇| 久久一二三国产| 宅男噜噜噜66国产日韩在线观看| 老牛影视一区二区三区| 亚洲一区免费| 亚洲人成毛片在线播放| 国产亚洲精品激情久久| 欧美三级电影一区| 免费在线观看一区二区| 欧美在线91| 中文一区二区在线观看| 亚洲高清在线| 久久综合色播五月| 欧美伊人久久久久久午夜久久久久 | 欧美国产精品中文字幕| 亚洲视频欧美视频| 亚洲高清在线观看一区| 国产精品一二一区| 欧美片在线观看| 久久资源av| 久久国产精品久久精品国产| 亚洲午夜成aⅴ人片| 亚洲人成网站777色婷婷| 美女久久一区| 欧美激情精品| 久久九九国产| 欧美中文在线观看国产| 亚洲欧美日韩在线播放| 一区二区高清视频| 亚洲伦理网站| 91久久亚洲| 最新日韩在线| 欧美激情久久久久久| 欧美ed2k| 欧美日韩伦理在线| 夜夜嗨av一区二区三区四季av | 欧美在线视频免费| 一区二区三区 在线观看视| 91久久精品一区二区别| 亚洲高清资源综合久久精品| 欧美成人中文字幕在线| 久久在线免费| 免播放器亚洲一区| 免费不卡在线观看av| 老司机午夜免费精品视频| 久久久久久久久久久一区 | 欧美肥婆在线| 欧美大片一区二区三区| 欧美xart系列在线观看| 欧美不卡视频| 欧美国产日韩免费| 欧美精品99| 欧美日韩国产片| 欧美视频国产精品| 国产精品女主播| 国产日韩一区二区三区在线播放 | 国产亚洲精品aa| 国产一区二区三区高清| 好看的亚洲午夜视频在线| 影音先锋另类| 亚洲三级电影在线观看| 在线视频亚洲| 午夜一区不卡| 久久久久一本一区二区青青蜜月| 久久一综合视频| 亚洲第一精品夜夜躁人人爽 | 欧美伦理91i| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲天堂av在线免费| 亚洲电影免费观看高清完整版| 一区二区三区在线免费观看| 一色屋精品视频在线观看网站| 亚洲电影第1页| 一级成人国产| 欧美专区18| 欧美大片在线看| 日韩视频在线你懂得| 亚洲一区美女视频在线观看免费| 欧美亚洲日本网站| 麻豆九一精品爱看视频在线观看免费| 欧美+亚洲+精品+三区| 亚洲高清不卡| 亚洲天堂av在线免费| 久久久久国产精品麻豆ai换脸| 亚洲最新合集| 性做久久久久久| 欧美va日韩va| 国产精品久久中文| 伊人激情综合| 亚洲视频一区二区免费在线观看| 久久精品国产v日韩v亚洲 | 欧美区亚洲区| 在线亚洲免费| 裸体歌舞表演一区二区| 亚洲国产精品第一区二区| 一本色道久久综合亚洲精品不 | 欧美日韩午夜| 国内揄拍国内精品少妇国语| 亚洲免费观看视频| 久久久久久国产精品一区| 亚洲精品国产日韩| 久久成人综合网| 欧美日韩另类视频| 国语自产偷拍精品视频偷| 一本色道久久88亚洲综合88| 久久影视三级福利片| 亚洲少妇自拍| 欧美a级在线| 国产性色一区二区| 亚洲视频一区二区在线观看| 欧美 日韩 国产在线| 亚洲欧美成aⅴ人在线观看| 欧美精品一区二区蜜臀亚洲 | 免费成人av在线| 亚洲经典在线看| 国产日韩欧美综合| 欧美三级视频在线观看| 国产日韩欧美视频在线| 日韩一区二区精品| 久久综合狠狠综合久久激情| 国产精品99久久不卡二区| 欧美91福利在线观看| 国产欧美日韩在线| 亚洲婷婷免费| 亚洲国产精品va在线看黑人动漫| 性感少妇一区| 国产精品亚洲综合| 亚洲图中文字幕| 91久久国产综合久久蜜月精品 | 亚洲欧美制服另类日韩| 欧美特黄一级大片| 日韩写真在线| 亚洲第一狼人社区| 久久午夜精品一区二区| 国内精品亚洲| 在线观看视频免费一区二区三区| 日韩一级大片| 亚洲欧美日本在线| 欧美一级网站| 一区二区三区久久久| 99国产精品久久久久久久成人热| 91久久精品久久国产性色也91| 日韩亚洲国产精品| 亚洲免费av电影| 亚洲欧美综合网| 玖玖玖免费嫩草在线影院一区| 你懂的网址国产 欧美| 亚洲国产精品久久久久| 一本色道久久综合亚洲精品按摩 | 久久爱www久久做| 久久精品视频导航| 亚洲毛片一区| 欧美成人一区二区在线| 老牛影视一区二区三区| 国产精品午夜电影| 欧美激情一区二区三区蜜桃视频 | 欧美激情久久久久| 国产精品99久久久久久久vr| 久久精品视频免费观看| 欧美有码在线视频| 国产视频自拍一区| 亚洲乱码精品一二三四区日韩在线 | av成人免费在线| 久久九九国产精品| 亚洲一二三区在线观看| 久久久www成人免费精品| 欧美a级一区二区| 亚洲乱码国产乱码精品精| 91久久久久久久久久久久久| 欧美激情一区二区三区四区| 夜夜嗨av一区二区三区| 亚洲网站在线播放| 国产日韩综合| 亚洲午夜激情免费视频| 亚洲永久在线观看| 欧美中文字幕在线观看| 在线播放不卡| 亚洲黑丝在线| 国产精品久久国产精品99gif| 欧美在线视频全部完| 久久精品中文|