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

隨筆-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 閱讀(2014) 評論(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在线| 一区二区高清| 亚洲欧美日韩在线一区| 久久精品人人做人人爽电影蜜月| 欧美国产日本韩| 国产麻豆成人精品| 亚洲黄色视屏| 欧美一级二级三级蜜桃| 狂野欧美一区| 99视频一区二区三区| 欧美在线视频一区二区| 欧美日韩天堂| 伊人成人网在线看| 亚洲一级在线观看| 久久综合色影院| 一区二区三区日韩精品| 久久国产欧美| 日韩亚洲成人av在线| 国产精品毛片大码女人| 亚洲三级免费电影| 久久久久综合网| 一区二区三区鲁丝不卡| 国产一区二区高清视频| 亚洲高清一区二| 久久动漫亚洲| 亚洲一级一区| 欧美日韩国产首页| 亚洲国产精品尤物yw在线观看 | 国产一区二区三区高清| 欧美电影资源| 久久gogo国模啪啪人体图| 亚洲人成亚洲人成在线观看| 久久深夜福利| 欧美日韩在线看| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美专区日韩专区| 日韩一级片网址| 亚洲第一视频网站| 久久成人资源| 欧美大色视频| 亚洲开发第一视频在线播放| 亚洲欧美国产另类| 亚洲美女在线一区| 在线观看日韩欧美| 亚洲自拍偷拍一区| 国产日韩在线亚洲字幕中文| 欧美主播一区二区三区美女 久久精品人| 裸体素人女欧美日韩| 永久免费视频成人| 亚洲欧美国产精品va在线观看| 亚洲精品麻豆| 麻豆国产精品va在线观看不卡| 欧美怡红院视频| 欧美一区二区三区四区在线| 亚洲视频在线观看一区| 亚洲一区日韩| 一区二区三区在线视频播放| 久久婷婷亚洲| 欧美成人日韩| 美女视频网站黄色亚洲| 国产日韩在线一区二区三区| 亚洲影院免费| 亚洲综合电影| 免费成人高清| 久久福利精品| 欧美成人蜜桃| 美女主播视频一区| 国产伊人精品| 久色婷婷小香蕉久久| 国产日本精品| 亚洲第一毛片| 最新亚洲电影| 欧美成年人网| 亚洲日本中文字幕区| 国产精品久久久91| 久久夜精品va视频免费观看| 国产亚洲精久久久久久| 欧美伊人久久| 欧美+亚洲+精品+三区| 国产精品国产三级国产| 亚洲视频一二| 最近中文字幕日韩精品| 欧美激情网站在线观看| 欧美一区二区三区精品电影| 国产视频在线观看一区| 久久精品一二三区| 亚洲大胆美女视频| 亚洲一区免费观看| 久久国产精品黑丝| 禁断一区二区三区在线| 欧美freesex交免费视频| 午夜精品福利在线| 欧美日韩成人网| 亚洲一区二区三区在线观看视频| 欧美主播一区二区三区美女 久久精品人| 国产免费亚洲高清| 免费亚洲一区| 亚洲一区二区视频在线观看| 久久一区二区精品| 在线中文字幕不卡| 国产一区二区电影在线观看| 欧美激情亚洲| 性色av香蕉一区二区| 正在播放日韩| 国产一区二区三区黄| 最近中文字幕日韩精品| 狠狠干综合网| 亚洲欧美日本国产有色| 免费成人高清视频| 亚洲男人av电影| 亚洲国产精品热久久| 国产精品久久久久久久午夜片| 久久久女女女女999久久| 99视频在线观看一区三区| 久热精品在线| 欧美一区二区三区在线观看视频| 在线精品亚洲| 久久亚洲一区| 欧美大片专区| 久久精品国产视频| 国产精品99久久99久久久二8| 伊人蜜桃色噜噜激情综合| 国产精品啊v在线| 亚洲欧美激情一区| 亚洲日本成人在线观看| 欧美 日韩 国产精品免费观看| 亚洲专区欧美专区| 日韩亚洲综合在线| 亚洲国产精品免费| 一区精品在线| 国产专区综合网| 国产日韩欧美亚洲一区| 国产精品日韩欧美一区| 午夜精品福利一区二区蜜股av| 亚洲精品久久久久久久久久久| 欧美成人亚洲成人| 狼人天天伊人久久| 久久香蕉国产线看观看av| 欧美一区二区视频97| 先锋影音国产精品| 亚洲欧美不卡| 性欧美激情精品| 欧美一区二区国产| 欧美一区二区三区在线看| 羞羞漫画18久久大片| 亚洲欧美视频在线观看视频| 亚洲综合电影| 欧美一二三区精品| 欧美自拍偷拍| 久久久久久久一区二区| 亚洲精品在线电影| 日韩午夜精品| 亚洲素人在线| 欧美一区二区三区四区高清 | 国产精品久在线观看| 欧美日韩综合视频网址| 亚洲免费视频观看| 午夜视频在线观看一区| 午夜精品福利一区二区三区av | 久久久蜜桃精品| 蜜臀av国产精品久久久久| 欧美成人精品三级在线观看| 欧美精品一区二区三区在线看午夜 | 国精产品99永久一区一区| 韩国精品在线观看| 亚洲激情啪啪| 亚洲新中文字幕| 久久久伊人欧美| 欧美激情成人在线| 久久精品一区二区三区不卡| 久久综合精品国产一区二区三区| 欧美二区不卡| 一区二区三区视频免费在线观看 | 免费影视亚洲| 亚洲精品乱码久久久久久黑人| 一区二区三区四区国产| 久久精品国产清高在天天线| av成人天堂| 欧美在线免费| 欧美国产亚洲另类动漫| 国产精品一区二区a| 亚洲欧洲日本在线| 亚洲欧美日韩一区二区在线| 免费看亚洲片| 亚洲性xxxx| 欧美aⅴ99久久黑人专区| 国产乱码精品一区二区三区五月婷 | 国产精品成人播放| 影音先锋成人资源站| 亚洲性视频网址| 免费成人黄色片| 亚洲一区二区成人在线观看| 久久综合中文色婷婷| 久久精品1区| 国产精品高清在线观看| 亚洲福利视频网| 久久国产精品久久久久久久久久| 亚洲福利免费|