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

隨筆 - 68  文章 - 57  trackbacks - 0
<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

常用鏈接

留言簿(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>
            亚洲精品欧美| 国产日韩欧美麻豆| 一区二区三区欧美亚洲| 欧美大片在线看免费观看| 久久久久国产免费免费| 久久全国免费视频| 久久久久国产精品午夜一区| 久久精品亚洲精品| 免费视频最近日韩| 亚洲国产小视频在线观看| 久久久蜜桃精品| 久久精品天堂| 亚洲人成小说网站色在线| 亚洲精品韩国| 午夜精品短视频| 美女999久久久精品视频| 玖玖综合伊人| 国产精品久久久久久久久久免费看| 欧美日韩国产一区| 一区久久精品| 久久国产精品一区二区三区四区| 久久免费视频在线观看| 一本色道久久综合亚洲精品按摩 | 欧美成人影音| 国产精品一区二区a| 亚洲国产精品悠悠久久琪琪| 这里只有精品视频在线| 久久躁日日躁aaaaxxxx| 亚洲图片欧美日产| 欧美精品福利视频| 亚洲精品国产无天堂网2021| 久久精品国产成人| 亚洲欧美另类在线观看| 国产精品久久久久久久久果冻传媒| 亚洲人成网站在线播| 欧美风情在线观看| 免费在线欧美视频| 日韩视频中文| 亚洲无亚洲人成网站77777| 欧美另类videos死尸| 亚洲深夜福利视频| 在线视频欧美一区| 国产日韩欧美一区二区| 久久婷婷综合激情| 欧美高清视频一二三区| 亚洲一区二区三区免费在线观看| 亚洲精品综合| 国产日本欧洲亚洲| 欧美国产先锋| 国产精品成人va在线观看| 久久精品亚洲乱码伦伦中文| 久久久xxx| 午夜一区不卡| 欧美mv日韩mv国产网站| 欧美日韩中文在线| 亚洲免费中文字幕| 麻豆国产精品一区二区三区| 一区二区三区精品视频| 久久高清福利视频| 亚洲午夜精品视频| 久久一区欧美| 久久这里只有精品视频首页| 欧美激情国产日韩| 久久久久免费视频| 国产精品theporn| 亚洲日韩视频| 亚洲激情视频在线播放| 午夜亚洲影视| 欧美一区二区三区成人| 国产精品www色诱视频| 亚洲区免费影片| 日韩一区二区久久| 欧美伦理91i| 99精品视频免费全部在线| 最新日韩av| 欧美日本一区| 这里只有精品视频| 亚洲欧美中文字幕| 国产精品三区www17con| 亚洲欧美在线一区| 亚洲激情av| 这里是久久伊人| 亚洲尤物影院| 亚洲高清视频在线观看| 狼人社综合社区| 久久av二区| 激情一区二区| 亚洲精品在线三区| 久久久久久亚洲精品中文字幕| 欧美另类人妖| 亚洲日本aⅴ片在线观看香蕉| 欧美专区日韩专区| 国产精品午夜av在线| 黄色日韩网站| 亚洲国产高清aⅴ视频| 一区三区视频| 免费日韩精品中文字幕视频在线| 欧美激情国产日韩| 亚洲在线视频网站| 激情综合五月天| 欧美三级午夜理伦三级中视频| 亚洲男同1069视频| 亚洲精品123区| 美女国内精品自产拍在线播放| 国产欧美日韩综合精品二区| 99v久久综合狠狠综合久久| 亚洲欧洲一区二区三区在线观看| 国产精品捆绑调教| 欧美日韩国产免费观看| 美女网站久久| 美女免费视频一区| 久久免费99精品久久久久久| 亚洲女性喷水在线观看一区| 亚洲精品一二| 亚洲性xxxx| 亚洲私人影吧| 先锋影音久久| 久久国产主播| 久久综合中文| 欧美精品三级在线观看| 欧美精品成人91久久久久久久| 欧美mv日韩mv国产网站app| 久久阴道视频| 欧美日韩美女在线观看| 欧美日韩一区综合| 国产日韩欧美黄色| 91久久国产综合久久| 亚洲一区二区毛片| 久久成人国产精品| 最新成人在线| 久久九九精品99国产精品| 亚洲主播在线| 亚洲欧美一区二区三区极速播放| 欧美亚洲专区| 亚洲国产精品久久91精品| 一区二区三区蜜桃网| 久久亚洲综合网| 国产精品私房写真福利视频| 亚洲第一精品久久忘忧草社区| 一区二区av在线| 久久在线视频在线| 欧美一级视频| 国产精品99免费看| 亚洲人体大胆视频| 欧美日韩免费区域视频在线观看| 国产精品jizz在线观看美国 | 另类尿喷潮videofree| 亚洲日韩中文字幕在线播放| 午夜视频一区| 国产日韩在线不卡| 欧美一区二区精品久久911| 日韩视频在线一区二区| 欧美大片一区| av成人毛片| 99成人免费视频| 欧美午夜精品伦理| 亚洲欧美日韩国产中文在线| 亚洲精品国产视频| 国产精品亚洲综合色区韩国| 亚洲天堂网在线观看| 在线视频你懂得一区| 国产精品国产馆在线真实露脸| 一区二区久久久久久| 亚洲视频福利| 国内精品久久久久久久影视麻豆| 老鸭窝毛片一区二区三区| 久久精品国语| 亚洲免费黄色| 欧美一区二区三区在线播放| 国产区二精品视| 久久综合久久久| 欧美伦理在线观看| 国产欧美精品在线播放| 欧美一区高清| 猫咪成人在线观看| 久久久.com| 欧美日韩精品高清| 美国三级日本三级久久99| 久久亚洲精选| 久久久av水蜜桃| 欧美日韩在线不卡一区| 久久久久综合| 欧美日韩免费观看一区三区| 久久成人综合网| 欧美日韩精品二区| 免费在线亚洲欧美| 国产午夜精品视频| 午夜精彩视频在线观看不卡| 国内精品久久久久久影视8| 91久久精品www人人做人人爽 | 欧美在线啊v| 中文在线不卡| 欧美成人a∨高清免费观看| 久久精品91| 国内精品福利| 久久精品噜噜噜成人av农村| 亚洲欧美日韩国产综合精品二区| 欧美91大片| 夜夜嗨av一区二区三区| 亚洲精选大片|