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

隨筆-80  評論-24  文章-0  trackbacks-0
先寫一下最樸素的O(N)算法,為了避免重復(fù)計(jì)算,這里不使用遞歸,而是采用循環(huán),代碼如下:

 1 int fibonacci(int n)
 2 {
 3     assert(n >= 0);
 4     if (n == 0return 0;
 5     if (n == 1return 1;
 6 
 7     int i = 2, tmp, a = 0, b = 1;
 8     for (; i <= n; ++i)
 9     {
10         tmp = b;
11         b = a + b;
12         a = tmp;
13     }
14     return b;
15 }
16 

這里重點(diǎn)介紹如下兩種方法,一種方法是《編程之美》上的,通過利用如下矩陣關(guān)系式:
[f(n), f(n-1)] = [f(1), f(0)] * [1, 1]^(n-1)
                                         [1, 0]
這樣就轉(zhuǎn)化成了求矩陣[1, 1]的n-1次冪了。
                            [1, 0]
我們知道求a^n的方法有l(wèi)og(N)級別的,類似的,利用分治的思想同樣可以求矩陣的n次冪。
代碼如下:

 1 typedef struct MATRIX
 2 {
 3     int a, b, c, d;
 4 } MATRIX;
 5
 6 MATRIX matrix_multiply(MATRIX A, MATRIX B)
 7 {
 8     MATRIX res;
 9     res.a = A.a * B.a + A.b * B.c;
10     res.b = A.a * B.b + A.b * B.d;
11     res.c = A.c * B.a + A.d * B.c;
12     res.d = A.c * B.b + A.d * B.d;
13     return res;
14 }
15 
16 MATRIX matrix_power(MATRIX A, int n)
17 {
18     assert(n > 0);
19     MATRIX tmp;
20     if (n == 1return A;
21     if (n % 2return matrix_multiply(A, matrix_power(A, n - 1));
22     tmp = matrix_power(A, n / 2);
23     return matrix_multiply(tmp, tmp);
24 }
25 
26 int fibonacci(int n)
27 {
28     assert(n >= 0);
29     if (n == 0return 0;
30     if (n == 1return 1;
31 
32     MATRIX identify = {1110};
33     identify = matrix_power(identify, n - 1);
34     return identify.a;
35 }
36 

其中matrix_multiply()用于計(jì)算兩個2*2的矩陣的乘積
matrix_power()用于計(jì)算矩陣A的n次冪
算法復(fù)雜度全部集中在matrix_power上,因此為log(N)級別

另外一種方法是今天上午靈感突現(xiàn),想到fibonacci數(shù)列遞推式的系數(shù)同樣符合fibonacci規(guī)律,如下:
f(n) = f(n - 1) + f(n - 2)
      = 2f(n - 2) + f(n - 3)
      = 3f(n - 3) + 2f(n - 4)
      = 5f(n - 4) + 3f(n - 5)
      = f(5)f(n - 4) + f(4)f(n - 5)
      = ...
      = f(i)f(n - i + 1) + f(i - 1)f(n - i)
有了這個公式我們可以得到如下式子:
f(2n) = f(n + 1)f(n) + f(n)f(n - 1) = f(n + 1)f(n) + f(n)[f(n + 1) - f(n)]
f(2n + 1) = f(n + 1)f(n + 1) + f(n)f(n)
所以可以得到:
f(2n) = [2f(n + 1) - f(n)]f(n)
f(2n + 1) = f(n + 1)f(n + 1) + f(n)f(n)
這樣,我們同樣找到了f(2x)與f(x)以及f(x+1)之間的關(guān)系,同樣可以得到log(N)級別的時(shí)間復(fù)雜度
程序如下:

 1 typedef struct MATRIX
 2 {
 3     int a, b;
 4 }MATRIX;
 5 
 6 MATRIX fibo(int n)
 7 {
 8     assert(n >= 0);
 9     MATRIX tmp = {01};
10     if (n == 0return tmp;
11     if (n == 1)
12     {
13         tmp.a = 1, tmp.b = 1;
14         return tmp;
15     }
16     tmp = fibo(n / 2);
17     int f2n = (2 * tmp.b - tmp.a) * tmp.a;
18     int f2n1= tmp.a * tmp.a + tmp.b * tmp.b;
19     if (n % 2)
20     {
21         tmp.a = f2n1, tmp.b = f2n1 + f2n;
22         return tmp;
23     }
24     else
25     {
26         tmp.a = f2n, tmp.b = f2n1;
27         return tmp;
28     }
29 }
30 
31 int fibonacci(int n)
32 {
33     assert(n >= 0);
34     return fibo(n).a;
35 }
36 
posted on 2012-02-09 15:20 myjfm 閱讀(586) 評論(0)  編輯 收藏 引用 所屬分類: 算法基礎(chǔ)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产专区精品视频| 亚洲视频在线播放| 欧美.www| 蜜臀久久99精品久久久久久9| 久久福利影视| 奶水喷射视频一区| 欧美日韩国产精品专区| 欧美日韩在线不卡一区| 国产精品日日做人人爱| 国产一区在线播放| 日韩小视频在线观看专区| 午夜精品久久久久久久蜜桃app| 欧美一区二区三区在线播放| 久久久久久高潮国产精品视| 欧美福利视频在线| 一区二区三区视频在线播放| 欧美一区二区三区婷婷月色| 久久综合色婷婷| 欧美午夜免费| 伊人狠狠色j香婷婷综合| 99在线精品视频| 久久国产精品一区二区三区四区| 欧美91福利在线观看| 亚洲作爱视频| 久久综合影音| 国产精品入口日韩视频大尺度| 激情综合亚洲| 亚洲欧美日韩精品久久奇米色影视| 久久久久久久综合日本| 亚洲国产成人91精品| 亚洲午夜一区二区| 久久综合婷婷| 好吊色欧美一区二区三区四区| 99视频精品| 男同欧美伦乱| 午夜在线视频观看日韩17c| 欧美激情久久久久久| 国产亚洲福利| 亚洲综合视频一区| 亚洲精品美女久久7777777| 久久久国产精品亚洲一区 | 亚洲视频高清| 久久亚洲私人国产精品va| 国产精品成av人在线视午夜片| 狠狠色狠色综合曰曰| 性亚洲最疯狂xxxx高清| 亚洲人线精品午夜| 麻豆成人精品| …久久精品99久久香蕉国产| 欧美制服丝袜第一页| 亚洲美女精品一区| 欧美寡妇偷汉性猛交| 在线精品视频一区二区| 久久久久亚洲综合| 欧美一区二视频| 午夜欧美理论片| 欧美午夜在线一二页| 一区二区福利| 亚洲欧洲日韩在线| 欧美黄色免费| 亚洲精品一品区二品区三品区| 麻豆freexxxx性91精品| 久久大综合网| 狠狠v欧美v日韩v亚洲ⅴ| 久久都是精品| 午夜激情综合网| 国产婷婷色一区二区三区| 香蕉乱码成人久久天堂爱免费 | 在线日韩中文字幕| 久久久久se| 久久精品免费播放| 国产专区综合网| 久久久久久久久久久成人| 欧美一级在线亚洲天堂| 国产一区视频在线观看免费| 欧美在线免费观看| 欧美一级久久久| 韩日欧美一区二区| 欧美大片在线看| 欧美精品九九| 亚洲视频在线播放| 午夜精品美女久久久久av福利| 国产日韩av高清| 美女在线一区二区| 女同一区二区| 亚洲视频在线免费观看| 日韩一级不卡| 国产精品一国产精品k频道56| 久久精品国产成人| 久久久亚洲高清| 一级日韩一区在线观看| 亚洲一区二区三区精品在线观看 | 影音先锋久久精品| 亚洲高清激情| 国产精品网站在线播放| 久久久久综合一区二区三区| 欧美成人dvd在线视频| 亚洲视频高清| 久久久激情视频| 亚洲天堂av综合网| 久久―日本道色综合久久| 一区二区三区久久网| 欧美一区二区三区精品| 亚洲精品美女在线观看| 亚洲欧美精品suv| 亚洲理论在线| 午夜精品视频| 一本色道久久88综合日韩精品 | 欧美精品日韩一区| 久久精品视频在线播放| 欧美日韩日本国产亚洲在线| 一本色道久久加勒比88综合| 亚洲网在线观看| 亚洲欧洲精品一区二区精品久久久| av成人免费在线观看| 影音先锋亚洲电影| 亚洲天堂av在线免费观看| 亚洲国产欧美日韩| 久久9热精品视频| 亚洲一级特黄| 欧美国产日本韩| 免费亚洲电影| 国产自产精品| 欧美一区二区在线观看| 亚洲欧美日韩综合aⅴ视频| 免费观看日韩| 欧美69wwwcom| 亚洲国产成人一区| 久久久不卡网国产精品一区| 欧美在线在线| 国产日韩欧美一区二区三区在线观看 | 在线免费观看日本一区| 亚洲欧美日韩精品久久久| 亚洲一卡久久| 欧美日韩国产综合视频在线观看中文| 欧美激情精品久久久久| 亚洲成人在线视频网站| 欧美一区二区三区在线视频| 亚洲一区尤物| 国产精品视频一二| 亚洲综合视频1区| 欧美影院精品一区| 国产网站欧美日韩免费精品在线观看 | 久久精品亚洲一区二区| 久久都是精品| 黄色小说综合网站| 久久久精品动漫| 欧美激情偷拍| 夜色激情一区二区| 欧美视频在线免费看| 一区二区日本视频| 小嫩嫩精品导航| 国产一区二区三区自拍| 久久久蜜桃一区二区人| 欧美高清在线视频观看不卡| 亚洲黄色天堂| 欧美日韩免费看| 亚洲一区美女视频在线观看免费| 亚洲欧美在线另类| 韩日欧美一区二区三区| 美女图片一区二区| 99精品视频免费观看| 欧美一区二区在线看| 黑人巨大精品欧美一区二区小视频| 久久夜色精品一区| 日韩一级精品| 久久人人97超碰精品888| 亚洲国产精品福利| 欧美午夜寂寞影院| 久久黄色网页| 欧美一区二区私人影院日本 | 中文日韩欧美| 国产区精品在线观看| 久久综合免费视频影院| 亚洲日韩第九十九页| 午夜精品三级视频福利| …久久精品99久久香蕉国产| 欧美久色视频| 久久精品国亚洲| 一区二区精品在线| 欧美91福利在线观看| 亚洲欧美日韩国产一区| 在线欧美电影| 国产女主播一区二区三区| 牛人盗摄一区二区三区视频| 亚洲无限乱码一二三四麻| 蜜桃av一区| 欧美制服丝袜| 亚洲欧美激情视频| 日韩视频免费在线观看| 国产一区二区毛片| 欧美视频在线一区| 欧美激情亚洲| 另类激情亚洲| 性色av一区二区三区红粉影视| av成人免费在线观看| 亚洲国产精品女人久久久| 久久综合色影院| 久久久亚洲欧洲日产国码αv| 亚洲欧美日韩在线不卡|