• <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>

            M.J的blog

            algorithm,ACM-ICPC
            隨筆 - 39, 文章 - 11, 評論 - 20, 引用 - 0
            數(shù)據(jù)加載中……

            TOJ 3428. Fibonacci(Fibonacci數(shù)列的一個規(guī)律)

            題意大概是給一組數(shù)M,N,求出第M個末位有N個0的Fibonacci數(shù)列是第幾項。
            乍一看,嚇我一跳,結(jié)果在2^31內(nèi),大的驚人。后來拿一個程序(正好是TOJ的一道題,求1000位內(nèi)的Fibonacci數(shù)列)暴力了下,好家伙,有規(guī)律的。
            第一個末位有1個0的是第15項,第二項第30…然后看末位有2個0的,第一個是150項,第二個第300項。然后很高興了寫了個程序,WA...
            有點暈,又暴力了下,加大范圍,發(fā)現(xiàn)第一個末位3個0的不是1500項,而是750項。無奈了,好奇怪。于是猜只有這一個特例,依然WA。最后請教了個
            學(xué)長,他說他也是猜的,不過后邊的確實都是10倍了,就那一個特例。
            接下來其實過程異常艱辛,不過最終思路很清晰,也AC了。
            --------------------------------------------------------我是低調(diào)的分割線-------------------------------------------------------------------------------------
            大概是這樣分布的:
            15             30            45     ...       150            165              180               195      ...          300        ...          750          ...          1500            ...           7500
            第1個0       第2個0         第3個0               第1個00          第10個0              第11個0               第12個0                  第2個00                     第1個000                                                                 第1個0000     
            ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
               

            所以可以看到,不能直接按間隔算,因為比如150.,它算2個0,而不是第10個1個0。
            又不能枚舉,一定會超時(確實超了)
            所以可以先按照沒有重疊算,然后加上重疊的,重疊的只算下一個就好,因為再后邊的也就都包括了。
            算重疊的部分要把特殊的2拿出來。倍數(shù)是5就是 4  1  4  1  4  1這樣分布,10的話就是 9  1  9  1  9  1  9  1  9  1,所以按照這樣算,
            比如要求第14個末位有2個0的,14%4!=0 ,14/4=3,所以重疊了3次。又比如20, 20%4==0,20/4-1=4,重疊4次。
            Code:
             1 #include<stdio.h>
             2 int main(void)
             3 {
             4     int a[18]={0,15,150,750,7500,75000,750000,7500000,75000000,750000000};         //保存第一個連續(xù)1個0,2個0的第一個
             5     int i,j,k,m,n,cas,key;
             6     scanf("%d",&cas);
             7     while(cas--){
             8         scanf("%d%d",&n,&m);
             9         key=m*a[n];
            10         if(n==2){
            11             if(m%4!=0) key+=(m/4)*a[n];
            12             else       key+=(m/4-1)*a[n];
            13         }
            14         else{
            15             if(m%9!=0) key+=(m/9)*a[n];
            16             else       key+=(m/9-1)*a[n];
            17         }
            18         printf("%d\n",key);
            19     }
            20 }

            posted on 2010-04-25 22:50 M.J 閱讀(1984) 評論(2)  編輯 收藏 引用

            評論

            # re: TOJ 3428. Fibonacci(Fibonacci數(shù)列的一個規(guī)律)  回復(fù)  更多評論   

            原來是這樣做。。。學(xué)習(xí)了
            2010-08-01 15:43 | superbear

            # re: TOJ 3428. Fibonacci(Fibonacci數(shù)列的一個規(guī)律)  回復(fù)  更多評論   

            學(xué)習(xí)了!
            2012-05-05 19:55 | wyl8899

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久午夜伦鲁片免费无码| 91麻豆国产精品91久久久| 精品久久人人爽天天玩人人妻| 国产婷婷成人久久Av免费高清| 韩国三级中文字幕hd久久精品| Xx性欧美肥妇精品久久久久久| 久久天天躁夜夜躁狠狠| 久久AV高清无码| 亚洲av日韩精品久久久久久a| 狠狠色丁香久久婷婷综合| 亚洲香蕉网久久综合影视| 久久精品国产99国产精品导航| 亚洲精品WWW久久久久久| 久久久久国产精品嫩草影院| 色综合久久久久综合体桃花网| 色欲久久久天天天综合网精品| 麻豆亚洲AV永久无码精品久久| 国产精品九九九久久九九| 久久人人爽爽爽人久久久| 久久精品国产亚洲av麻豆色欲 | 国产69精品久久久久9999| 久久久久国产视频电影| 久久午夜夜伦鲁鲁片免费无码影视| 色播久久人人爽人人爽人人片AV| 亚洲精品乱码久久久久久中文字幕 | 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久精品国产一区二区| 色99久久久久高潮综合影院| 精品久久久久成人码免费动漫| 国产69精品久久久久9999APGF| 狠狠色丁香婷婷久久综合不卡| 久久久久亚洲AV成人网| 国产精品99久久久精品无码| 久久亚洲国产中v天仙www| 日韩影院久久| 久久本道伊人久久| 久久精品国产亚洲av麻豆蜜芽 | 亚洲日韩中文无码久久| 亚洲狠狠综合久久| 久久亚洲精品人成综合网| 久久久久亚洲?V成人无码|