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

隨筆-80  評論-24  文章-0  trackbacks-0
問題1,求N!的十進制表示中末尾0的個數。
直接求出N!不太現實,很容易溢出。這個問題比較容易想到的是,因為2X5=10,所以可以求N!含有的因子2和因子5的個數??梢赃@樣表示N!=2x * 3y * 5z * 7a *...,在這個表達式中,我們容易得出x > z,因此只需要計算N!中含有因子5的個數,進而可以轉化成計算1-N這N個數含有因子5的個數之和,所以可以寫出代碼:

 1 int factorial1(int n) {
 2   int count = 0;
 3   while (n) {
 4     int m = n;
 5     while (m > 0 && m % 5 == 0) {
 6       count++;
 7       m /= 5;
 8     }   
 9     n--;
10   }
11   return count;
12 }

可以發現,上面的算法復雜度為O(Nlog5N),當N比較大時比如N=1000000000時,上面算法需要大概11s的時間,仔細想想,發現上面其實判斷了很多不需要判斷的值,因為很多數根本就不能被5整除,但是依然在外層while循環中被計算,所以我們可以只計算能被5整除的數,算法如下:

 1 int factorial2(int n) {
 2   int count = 0;
 3   n = (n / 5) * 5;
 4   while (n > 0) {
 5     int m = n;
 6     while (m > 0 && m % 5 == 0) {
 7       count++;
 8       m /= 5;
 9     }   
10     n -= 5;
11   }
12   return count;
13 }

上面算法從比n小的最大的能被5整除的數開始計算,且每次計算的步長為5,即跳過不是5的倍數的數,時間復雜度為O((Nlog5N)/5) ,當n=1000000000時,上面程序大概運行5s,較上一算法有所改進,不過復雜度沒有質的飛躍,籠統來說還是O(NlogN)。那么怎么進一步降低復雜度呢?
下面的算法就需要好好考慮如下事實:
1-N這N個數中有N/5個數是5的倍數
1-N這N個數中有N/52個數是52的倍數
1-N這N個數中有N/53個數是53的倍數
...
這樣就比較明了了,容易得到如下算法:

1 int factorial3(int n) {
2   int count = 0;
3   while (n > 0) {
4     n /= 5;
5     count += n;
6   }
7   return count;
8 }

上面的算法復雜度為O(log5N),對n=1000000000,上面算法只運行了0.004s。

問題2,求N!的二進制表示中末尾0的個數。 
該問題和上面的問題其實非常相似,稍作轉化就成為求N!中2的因子數,這樣就可以用上面的算法來解決:

1 int factorial3(int n) {
2   int count = 0;
3   while (n > 0) {
4     n >>= 1;
5     count += n;
6   }
7   return count;
8 }

這兩個問題的難點在轉化成求5或者2因子的個數;并且善于深入挖掘問題,編碼降低復雜度。
posted on 2012-09-04 12:24 myjfm 閱讀(2012) 評論(0)  編輯 收藏 引用 所屬分類: 算法基礎
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            在线观看日韩精品| 午夜久久影院| 亚洲一区自拍| 一区二区三区四区五区在线| 亚洲乱码视频| 亚洲天堂av图片| 欧美亚洲专区| 久久午夜av| 欧美激情一区二区三区不卡| 最新国产乱人伦偷精品免费网站| 久久久综合网站| 欧美天天综合网| 日韩视频永久免费| 宅男噜噜噜66国产日韩在线观看| 亚洲婷婷国产精品电影人久久| 一区二区三区日韩| 欧美一区久久| 欧美日韩高清在线| 国产日韩欧美视频| 亚洲第一页自拍| 亚洲在线成人| 美女国产一区| 亚洲一区二区三区国产| 久久亚洲精品一区二区| 欧美午夜电影一区| 在线观看一区二区精品视频| 亚洲自拍另类| 亚洲高清视频中文字幕| 午夜精品久久久久久久| 欧美激情亚洲一区| 一区在线免费| 欧美一区二区三区在线播放| 女人香蕉久久**毛片精品| 国产精品99久久99久久久二8| 久久av一区二区三区漫画| 欧美日韩精品一区二区三区四区| 国内成+人亚洲+欧美+综合在线| 日韩视频在线观看国产| 美女诱惑黄网站一区| 亚洲自拍偷拍麻豆| 玖玖玖国产精品| 国产伊人精品| 亚洲小说欧美另类婷婷| 欧美高清在线播放| 亚洲欧美日韩国产一区二区| 欧美伦理视频网站| 亚洲三级网站| 欧美激情精品久久久久久黑人| 欧美一区2区三区4区公司二百| 国产精品成人va在线观看| 99riav1国产精品视频| 欧美高清视频在线播放| 久久中文在线| 亚洲国产精品成人| 老司机一区二区三区| 亚洲欧美制服另类日韩| 欧美午夜一区二区福利视频| 亚洲精品综合| 亚洲日本乱码在线观看| 欧美电影免费观看高清| 亚洲精品乱码久久久久久日本蜜臀| 牛牛国产精品| 欧美福利视频网站| 日韩亚洲不卡在线| 亚洲精品久久久久久下一站 | 日韩午夜在线播放| 亚洲激情在线观看| 免费亚洲一区二区| 91久久国产综合久久| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲在线网站| 国产日韩一区在线| 久久夜色精品国产| 久久亚洲综合色| 亚洲精品永久免费| 亚洲精品中文字幕女同| 欧美日本一区| 亚洲欧美日韩一区二区在线| 亚洲永久在线观看| 国产日韩一级二级三级| 蜜月aⅴ免费一区二区三区| 久热成人在线视频| 亚洲精品一二三区| 一本久久a久久精品亚洲| 国产精品久久久久久久久久妞妞| 香蕉国产精品偷在线观看不卡| 香蕉亚洲视频| 亚洲电影专区| 日韩一级黄色大片| 国产欧美综合在线| 欧美成人一区二区在线 | 国产丝袜一区二区三区| 久久夜色精品一区| 欧美福利电影在线观看| 亚洲欧美国产精品桃花| 久久女同精品一区二区| 亚洲一本视频| 麻豆精品视频在线观看视频| 亚洲一级网站| 久久亚洲影音av资源网| 亚洲亚洲精品在线观看 | 免费亚洲一区二区| 亚洲免费影院| 美日韩在线观看| 亚洲欧美激情四射在线日| 久久久综合网站| 亚洲欧美日韩另类| 麻豆精品精华液| 久久精品人人做人人综合| 欧美成人精品不卡视频在线观看| 亚洲视频欧美在线| 久久久一本精品99久久精品66| 国产精品99久久久久久宅男| 久久精品国产一区二区三区| 宅男精品导航| 欧美大色视频| 欧美成人精品| 国产一区二区三区精品久久久| 亚洲国产精品一区制服丝袜| 国产性色一区二区| 亚洲小说春色综合另类电影| 亚洲精品美女免费| 久久美女艺术照精彩视频福利播放| 亚洲电影下载| 91久久精品国产91久久性色tv | 欧美美女bbbb| 老司机午夜精品| 国产精品永久免费| 一本色道久久综合亚洲精品不| 亚洲欧洲日产国产网站| 久久久av毛片精品| 久久久久久综合| 国产日韩在线看片| 亚洲小视频在线观看| 午夜日本精品| 国产精品一区二区黑丝| 一本色道久久综合狠狠躁的推荐| 亚洲伦理自拍| 欧美另类人妖| 日韩一区二区免费看| 在线亚洲欧美| 国产精品大全| 亚洲欧美第一页| 久久久天天操| 亚洲国产精品福利| 欧美高清一区二区| 亚洲精品少妇30p| 亚洲天堂网在线观看| 国产精品青草综合久久久久99 | 99热免费精品| 欧美日韩网站| 亚洲自拍偷拍福利| 久久一区二区三区国产精品| 精品69视频一区二区三区| 美女精品在线观看| 亚洲精品国产精品国自产观看浪潮| 最新国产精品拍自在线播放| 欧美好骚综合网| 亚洲一级黄色| 久久伊人亚洲| 一本色道久久99精品综合 | 中文日韩欧美| 欧美在线播放一区二区| 黄色精品免费| 欧美极品色图| 亚洲男人影院| 欧美成年人视频| 亚洲特色特黄| 伊人激情综合| 欧美视频三区在线播放| 久久精品国产一区二区三区免费看| 91久久国产综合久久91精品网站| 亚洲午夜av在线| 韩国亚洲精品| 欧美日韩在线电影| 久久久久www| 99综合电影在线视频| 久久亚洲精品欧美| 亚洲小视频在线| 亚洲日韩视频| 一区二区在线视频| 国产精品久久久久久福利一牛影视| 性欧美暴力猛交69hd| 亚洲人午夜精品免费| 久久人人精品| 亚洲一区二区三区久久| 136国产福利精品导航| 欧美日韩精品伦理作品在线免费观看 | 亚洲一区国产视频| 欧美二区在线播放| 午夜宅男欧美| 99xxxx成人网| 亚洲欧洲偷拍精品| 国产亚洲欧美一区| 国产精品国产三级国产普通话99| 欧美成人免费网| 久久久久久久久久久久久女国产乱 | 一区二区三区久久| 亚洲国产精品成人综合色在线婷婷 | 欧美成人一区二区三区|