• <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++博客 :: 首頁(yè) ::  :: 聯(lián)系 ::  :: 管理

            Google面試題之補(bǔ)充

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

            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++版本。主循環(huán)也要略微改變一下:

            void
            solve()
            {

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


            可以看到,現(xiàn)在循環(huán)從大到小。little函數(shù)找到下一個(gè)可能滿足題目約束的i。在little函數(shù)中,首先計(jì)算小于i的1的個(gè)數(shù)ones,如果ones和i相等,就將i輸出(這就是題目要求干的事)。如果i小于ones,那么就要在小于i的自然數(shù)中找下一個(gè)可能滿足條件的數(shù)。因?yàn)樗阉鞯姆秶怀^(guò)10^10,所以一個(gè)數(shù)中至多含有9個(gè)1,按照這種極端情況,也必須將i減少(ones-i)/8才有可能滿足條件(這里之所以是8,因?yàn)橥瑫r(shí)i也減少了)。如果i大于ones,考慮一個(gè)小于i的數(shù)i',可以考慮一下calc_ones(i')的取值,極端情況,[i',i)的范圍內(nèi)的整數(shù)沒(méi)有一個(gè)包含1,也就是說(shuō)當(dāng)i減少到i'時(shí)1的個(gè)數(shù)沒(méi)有損失,那么calc_ones(i') = calc_ones(i),如果i'>calc_ones(i),則就有i'>calc_ones(i'),直到i'=calc_ones(i),因此下一個(gè)需要查看的數(shù)就是calc_ones(i)。其實(shí)上面這一段討論可以用一個(gè)式子來(lái)概括:對(duì)i'<i,calc_ones(i)-9*(i-i') <= calc_ones(i') <= calc_ones(i)。這樣就能大大提高速度了。

            Feedback

            # re: Google面試題之補(bǔ)充  回復(fù)  更多評(píng)論   

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

            # re: Google面試題之補(bǔ)充  回復(fù)  更多評(píng)論   

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

            # re: Google面試題之補(bǔ)充  回復(fù)  更多評(píng)論   

            2006-09-17 13:25 by chenger
            后來(lái)我也覺(jué)得那個(gè)不正經(jīng)。
            我認(rèn)為還是正經(jīng)解決一下比較好。做到這個(gè)份上,也差不多了。

            # re: Google面試題之補(bǔ)充  回復(fù)  更多評(píng)論   

            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;
            }
            亚洲一本综合久久| 久久久精品国产sm调教网站| 久久久青草青青亚洲国产免观| 高清免费久久午夜精品| 久久国产成人午夜aⅴ影院 | 人人狠狠综合久久亚洲婷婷| 久久精品国产色蜜蜜麻豆| 亚洲va国产va天堂va久久| 成人亚洲欧美久久久久 | 国产精品一区二区久久精品无码 | 久久久久久久久久免免费精品| 国产精品99久久久精品无码| 狠狠色丁香婷婷久久综合不卡| 久久精品国产亚洲5555| 久久综合久久综合久久综合| 久久人人爽人人爽人人av东京热| 91久久精一区二区三区大全| 亚洲欧美日韩精品久久亚洲区| 四虎国产精品免费久久久| 久久久av波多野一区二区| 久久精品国产99久久久古代| 久久丝袜精品中文字幕| 国产毛片久久久久久国产毛片 | 大伊人青草狠狠久久| 久久精品亚洲日本波多野结衣| 亚洲午夜精品久久久久久app| 麻豆精品久久久一区二区| 久久久老熟女一区二区三区| 久久精品国产亚洲AV忘忧草18| 国产亚洲精午夜久久久久久 | 亚洲国产成人久久综合区| 国内精品久久久久久久久电影网| 久久国产高潮流白浆免费观看| 亚洲精品无码久久久久去q| 精品久久亚洲中文无码| 久久99这里只有精品国产| 国产精品成人久久久| 久久精品亚洲日本波多野结衣 | 热RE99久久精品国产66热| 欧美日韩中文字幕久久久不卡| 久久男人中文字幕资源站|