• <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>
              C++博客 :: 首頁 ::  :: 聯系 ::  :: 管理

            Google面試題之補充

            Posted on 2006-09-16 15:35 chenger 閱讀(887) 評論(4)  編輯 收藏 引用 所屬分類: Programming Stuff
            上次寫了一篇關于google面試題的文章。我給的算法跑得很慢,后面張沈鵬同學用python寫了一個算法,速度很快(再次感覺python的性能不像想象中那么壞,當然和算法有關),看了一下他的代碼,函數count(i)用來計算小于i的1的個數,和我寫的calc_ones算法基本相同,只不過count(i)用了遞歸,看上去更清楚一些。主要的速度差別在little(i)函數上,這個函數避免了很多迭代:

            size_t little(size_t i)
            {

            ???
            size_t ones = calc_ones(i);
            ??? if(ones == i)
            ??????? cout << i <<
            "\n";
            ??? if(i < ones)
            ??????? if
            ((ones - i)/9 > 1)
            ??????????? return
            i - (ones - i)/8;
            ??? if
            (i > ones)
            ??????? return
            ones;
            ??? return
            i - 1;
            }


            這是C++版本。主循環也要略微改變一下:

            void
            solve()
            {

            ??? size_t
            max = 10000000000;
            ??? for
            (size_t i = max;i > 0;i = little(i));
            }


            可以看到,現在循環從大到小。little函數找到下一個可能滿足題目約束的i。在little函數中,首先計算小于i的1的個數ones,如果ones和i相等,就將i輸出(這就是題目要求干的事)。如果i小于ones,那么就要在小于i的自然數中找下一個可能滿足條件的數。因為搜索的范圍不超過10^10,所以一個數中至多含有9個1,按照這種極端情況,也必須將i減少(ones-i)/8才有可能滿足條件(這里之所以是8,因為同時i也減少了)。如果i大于ones,考慮一個小于i的數i',可以考慮一下calc_ones(i')的取值,極端情況,[i',i)的范圍內的整數沒有一個包含1,也就是說當i減少到i'時1的個數沒有損失,那么calc_ones(i') = calc_ones(i),如果i'>calc_ones(i),則就有i'>calc_ones(i'),直到i'=calc_ones(i),因此下一個需要查看的數就是calc_ones(i)。其實上面這一段討論可以用一個式子來概括:對i'<i,calc_ones(i)-9*(i-i') <= calc_ones(i') <= calc_ones(i)。這樣就能大大提高速度了。

            Feedback

            # re: Google面試題之補充  回復  更多評論   

            2006-09-17 12:57 by 張沈鵬
            sorry,我有個筆誤
            (count_i-i)/9
            =>
            (count_i-i)/8
            至多含有9個1,count每次最多減9,而i-=1,所以差距至多-8,
            這樣會更快一點

            # re: Google面試題之補充  回復  更多評論   

            2006-09-17 13:19 by 張沈鵬
            說實話,第一次我和你說的算法是指的
            fastrun()
            不過后來你叫我把算法給你看看,我覺得這種奇技淫巧不好意思拿出手
            只好想了一個算法
            不過,我還是覺得fastrun比run更有價值,我想這也是Google面試的本意吧:)

            # re: Google面試題之補充  回復  更多評論   

            2006-09-17 13:25 by chenger
            后來我也覺得那個不正經。
            我認為還是正經解決一下比較好。做到這個份上,也差不多了。

            # re: Google面試題之補充  回復  更多評論   

            2007-08-16 14:17 by 哈胖頭
            Show一下我的程序:

            int count_ones(int n)
            {
            static int pow10[]={1, 10, 100, 1000, 10000, 100000, 1000000, 10000000, 100000000, 1000000000};

            int ones=0;

            for(int m=n, b=0; m; m/=10, b++)
            {
            int d=m%10;
            ones+=d*pow10[b]*b/10;
            if(d>1) ones+=pow10[b];
            if(d==1) ones+=n%pow10[b];
            }

            return ones;
            }
            色天使久久综合网天天| 久久天天躁狠狠躁夜夜av浪潮| 精品人妻伦九区久久AAA片69| 精品国产乱码久久久久软件| 狼狼综合久久久久综合网| 久久亚洲国产欧洲精品一| 久久久精品波多野结衣| 久久精品国产男包| 久久99热国产这有精品| 亚洲精品美女久久久久99小说| 久久99国内精品自在现线| 精品久久久久久无码中文字幕| 亚洲愉拍99热成人精品热久久| 精品久久久久久综合日本| 久久久久国产精品嫩草影院| 久久精品成人免费看| 少妇高潮惨叫久久久久久| 久久精品国产一区二区三区| 久久香蕉超碰97国产精品 | 人人狠狠综合久久88成人| 亚洲国产精品久久久久婷婷软件 | 久久精品aⅴ无码中文字字幕不卡| 国产一区二区三精品久久久无广告| 亚洲AV日韩精品久久久久久| 久久久精品久久久久特色影视| 精品无码久久久久国产| 久久精品中文无码资源站| 亚洲美日韩Av中文字幕无码久久久妻妇| 7777久久亚洲中文字幕| 蜜臀久久99精品久久久久久小说| 一级做a爰片久久毛片看看| 日韩美女18网站久久精品| 国内精品久久久久国产盗摄| 色综合久久中文综合网| 2020久久精品国产免费| 国产成人久久精品区一区二区| 久久久久人妻一区精品色| 久久久久亚洲av无码专区导航| 日本欧美久久久久免费播放网| 香蕉久久av一区二区三区 | 久久亚洲色一区二区三区|