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

隨筆 - 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>
            久久精品视频免费播放| 亚洲一区免费观看| 亚洲欧美国产日韩天堂区| 久久中文久久字幕| 亚洲国产精品久久人人爱蜜臀| 欧美性猛交xxxx乱大交蜜桃| 在线午夜精品自拍| 亚洲欧美综合v| 欧美大胆a视频| 亚洲天堂av电影| 久久综合九色综合久99| 亚洲国产日韩在线一区模特| 亚洲三级影院| 国产日韩欧美高清免费| 午夜精品一区二区三区四区 | 亚洲国产高清高潮精品美女| 久久久久久9| 日韩视频―中文字幕| 欧美国产日本| 欧美成人一区二区三区片免费| 久久久久国产免费免费| 先锋影音久久久| 久久se精品一区二区| 久久久久久久久久久久久女国产乱| 夜夜嗨av一区二区三区中文字幕 | 欧美成人久久| 亚洲第一在线| 国产综合色在线| 国产精品二区三区四区| 欧美国产精品久久| 99国产成+人+综合+亚洲欧美| 欧美精品在线观看91| 久久久噜噜噜久噜久久| 久久精品国产清自在天天线| 欧美专区日韩视频| 最新69国产成人精品视频免费| 久久久精品999| 国产亚洲午夜| 欧美激情视频网站| 欧美h视频在线| 亚洲视频图片小说| 亚洲一区二区三区四区在线观看| 国产欧美日韩一区| 国内一区二区三区| 日韩一级裸体免费视频| 亚洲欧美春色| 免费成人网www| 美国十次了思思久久精品导航| 亚洲福利免费| 黄色成人精品网站| 国产精品区一区| 99香蕉国产精品偷在线观看| 新狼窝色av性久久久久久| 免费成人毛片| 亚洲欧美精品| 欧美承认网站| 国产一区二区三区在线观看免费视频 | 亚洲天堂免费在线观看视频| 欧美一区视频在线| 欧美精品免费看| 红桃视频亚洲| 久久国产精品99久久久久久老狼| 久久综合电影| 欧美激情一区二区三级高清视频| 午夜一级在线看亚洲| 欧美日韩精品在线视频| 伊人一区二区三区久久精品| 欧美一区二区三区四区在线观看地址| 亚洲高清一区二区三区| 久久精品一二三| 国产日韩精品一区二区三区| 狠狠色丁香婷婷综合久久片| 亚洲精品国产视频| 美女主播一区| 久久国产精品亚洲77777| 国产麻豆综合| 亚洲一区视频在线观看视频| 亚洲开发第一视频在线播放| 欧美精品七区| av成人国产| 亚洲精品影院在线观看| 久久超碰97人人做人人爱| 欧美激情四色| 99re国产精品| 亚洲肉体裸体xxxx137| 欧美成人一区二区在线| 在线电影院国产精品| 久久―日本道色综合久久| 欧美在线观看一区二区| 一区二区三区在线免费播放| 亚洲影视在线播放| 亚洲一区在线免费| 国产日韩欧美不卡| 久久人体大胆视频| 美国十次成人| 亚洲精品久久久久久一区二区| 亚洲高清不卡在线| 欧美成人精品激情在线观看| 亚洲国产精品成人久久综合一区| 免费国产一区二区| 亚洲在线中文字幕| 国产亚洲欧洲997久久综合| 久久福利资源站| 亚洲社区在线观看| 美女亚洲精品| 欧美另类99xxxxx| 亚洲精品一区二区三| 亚洲裸体视频| 国产精品丝袜xxxxxxx| 欧美在线观看网站| 99视频超级精品| 国产精品一卡二| 免费一级欧美片在线播放| 噜噜噜91成人网| 亚洲午夜精品久久| 老司机精品导航| 久久精品99国产精品| 在线欧美日韩精品| 亚洲伊人观看| 午夜久久影院| 欧美日韩在线免费观看| 亚洲欧美久久久久一区二区三区| 欧美一区二区三区播放老司机| 亚洲观看高清完整版在线观看| 亚洲激情在线激情| 国产嫩草一区二区三区在线观看| 免费亚洲电影| 国产精品系列在线播放| 欧美高清在线播放| 国产精品免费视频观看| 欧美激情一区二区三级高清视频| 国产精品videossex久久发布| 老巨人导航500精品| 欧美成人免费全部| 久久激情综合| 国产精品久久久久久模特| 亚洲电影免费观看高清完整版在线| 国产精品人人做人人爽人人添| 亚洲国产精彩中文乱码av在线播放| 欧美大片在线观看一区| 久久免费的精品国产v∧| 欧美视频一区二区三区在线观看| 免费不卡亚洲欧美| 国产欧美一区在线| 亚洲一区免费视频| 中文在线不卡| 欧美剧在线免费观看网站| 免费亚洲电影在线| 精品福利av| 欧美一区二区三区四区在线观看| 国产精品99久久99久久久二8| 久久字幕精品一区| 欧美激情精品久久久久久| 日韩一区二区高清| 国产精品va在线播放| 午夜老司机精品| 牛人盗摄一区二区三区视频| 亚洲经典自拍| 欧美三级黄美女| 亚洲女同性videos| 麻豆久久婷婷| 99riav久久精品riav| 国产精品第13页| 久久精品一区二区国产| 亚洲国产另类久久精品| 亚洲小说春色综合另类电影| 国产午夜精品麻豆| 欧美日韩激情网| 乱中年女人伦av一区二区| 在线午夜精品自拍| 亚洲一区国产一区| 在线欧美不卡| 夜夜精品视频| 亚洲精品国产日韩| 久久久久久亚洲精品杨幂换脸| 日韩午夜三级在线| 久久久久国产一区二区三区| 亚洲无线观看| 欧美不卡视频一区| 美女啪啪无遮挡免费久久网站| 欧美日韩另类视频| 亚洲国产高清一区二区三区| 激情欧美一区二区三区| 在线视频亚洲欧美| 亚洲看片一区| 欧美国产一区二区| 亚洲人成在线免费观看| 在线观看亚洲专区| 免费美女久久99| 久久露脸国产精品| 激情成人在线视频| 久久久不卡网国产精品一区| 久久经典综合| 在线播放精品| 欧美bbbxxxxx| 99精品黄色片免费大全| 99视频日韩| 国产欧美一区二区在线观看| 午夜精品久久久久久久99樱桃 | 亚洲综合三区|