• <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>
            隨筆-80  評論-24  文章-0  trackbacks-0
            問題1,求N!的十進制表示中末尾0的個數(shù)。
            直接求出N!不太現(xiàn)實,很容易溢出。這個問題比較容易想到的是,因為2X5=10,所以可以求N!含有的因子2和因子5的個數(shù)。可以這樣表示N!=2x * 3y * 5z * 7a *...,在這個表達式中,我們?nèi)菀椎贸鰔 > z,因此只需要計算N!中含有因子5的個數(shù),進而可以轉(zhuǎn)化成計算1-N這N個數(shù)含有因子5的個數(shù)之和,所以可以寫出代碼:

             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 }

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

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

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

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

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

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

            這兩個問題的難點在轉(zhuǎn)化成求5或者2因子的個數(shù);并且善于深入挖掘問題,編碼降低復(fù)雜度。
            posted on 2012-09-04 12:24 myjfm 閱讀(1991) 評論(0)  編輯 收藏 引用 所屬分類: 算法基礎(chǔ)
            国产亚州精品女人久久久久久| 国产成人无码精品久久久久免费 | 国产综合精品久久亚洲| 精品无码久久久久久国产| 欧美日韩成人精品久久久免费看| 奇米影视7777久久精品人人爽| 成人国内精品久久久久一区| 久久久久国产一区二区三区| 久久av无码专区亚洲av桃花岛| 91精品免费久久久久久久久| 囯产精品久久久久久久久蜜桃| 99久久精品国产一区二区三区 | 国产国产成人久久精品| 久久久久亚洲国产| 99久久国产综合精品成人影院| 久久综合偷偷噜噜噜色| 精品久久久久久国产三级| 久久久久人妻一区二区三区vr| 日韩美女18网站久久精品| 色综合久久中文色婷婷| 国产V综合V亚洲欧美久久| 亚洲午夜久久久久久噜噜噜| 久久久精品视频免费观看| 亚洲综合婷婷久久| 久久美女人爽女人爽| 久久久久综合网久久| 97久久精品无码一区二区| 亚洲色欲久久久综合网| 久久婷婷色香五月综合激情| 污污内射久久一区二区欧美日韩| 国产福利电影一区二区三区久久久久成人精品综合 | 99久久无码一区人妻a黑| 精品一二三区久久aaa片| 久久亚洲电影| 亚洲国产成人精品无码久久久久久综合| 精品久久久久国产免费| 色综合久久久久综合99| 久久久午夜精品福利内容| 亚洲精品tv久久久久久久久 | 久久这里的只有是精品23| 久久最新免费视频|