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

  C++博客 :: 首頁 ::  :: 聯系 ::  :: 管理

Google面試題之補充

Posted on 2006-09-16 15:35 chenger 閱讀(912) 評論(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;
}
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 久久精品国产精品| 欧美国产一区二区| 亚洲精品在线看| 亚洲一区日韩在线| 久久国产精品一区二区| 免费不卡亚洲欧美| 国产精品三上| 91久久精品国产91久久性色tv| 亚洲精品欧美一区二区三区| 亚洲欧美日韩一区二区在线| 久久天天躁狠狠躁夜夜av| 亚洲福利av| 一区二区免费看| 久久久一区二区| 欧美日韩性视频在线| 国模叶桐国产精品一区| 日韩一区二区久久| 久久午夜影视| 欧美日韩国产色视频| 欧美在线地址| 亚洲综合精品四区| 亚洲欧美久久久| 久久综合狠狠综合久久综青草| 亚洲激情成人| 欧美专区在线观看一区| 欧美日韩亚洲不卡| 亚洲三级电影在线观看| 久久一区二区三区国产精品| 亚洲网站在线观看| 欧美另类极品videosbest最新版本 | 午夜精品久久久久久久久久久久久 | 久久九九国产精品| 欧美特黄a级高清免费大片a级| 在线播放豆国产99亚洲| 亚洲综合日韩中文字幕v在线| 亚洲福利视频二区| 久久婷婷成人综合色| 国产午夜精品美女视频明星a级| 亚洲一区二区3| 亚洲精品一区中文| 欧美另类一区二区三区| 亚洲理论电影网| 欧美国产精品久久| 久久精品国产一区二区三区免费看| 欧美系列精品| 亚洲女人天堂成人av在线| 亚洲最新色图| 欧美性猛交xxxx乱大交退制版| 亚洲乱亚洲高清| 亚洲茄子视频| 欧美全黄视频| 亚洲欧美国产一区二区三区| 亚洲免费高清| 国产精品国产| 欧美一级在线视频| 性色av一区二区三区| 国产午夜精品理论片a级大结局 | 欧美精品福利视频| 亚洲区在线播放| 亚洲国产精品久久久久婷婷老年| 欧美寡妇偷汉性猛交| 一本大道久久a久久综合婷婷| 欧美成人激情在线| 欧美日韩亚洲一区二区三区四区| 亚洲日本理论电影| 亚洲国产日韩在线一区模特| 欧美成人国产一区二区| 亚洲免费观看在线观看| 99riav国产精品| 国产精品一区二区三区免费观看| 午夜欧美不卡精品aaaaa| 先锋亚洲精品| 亚洲欧洲视频| 宅男66日本亚洲欧美视频| 国产精品一区二区在线观看不卡| 久久成人一区| 欧美a级一区二区| 亚洲欧美日韩精品| 久久精品最新地址| 一本大道久久a久久精品综合| 亚洲一品av免费观看| 影音先锋亚洲视频| 艳女tv在线观看国产一区| 国产偷国产偷精品高清尤物| 亚洲第一色在线| 国产精品视频久久久| 欧美成人精品高清在线播放| 欧美日韩综合在线免费观看| 麻豆成人综合网| 国产精品对白刺激久久久| 老巨人导航500精品| 欧美午夜精品久久久久久久| 免费看的黄色欧美网站| 国产精品日韩在线观看| 亚洲电影在线免费观看| 国产日韩欧美一区在线 | 久久国产加勒比精品无码| 久热精品在线| 久久福利电影| 欧美日韩一区二区国产| 欧美xxx成人| 国产一区二区精品| 一区二区高清在线观看| 亚洲国产成人av| 亚洲欧美日韩综合| 亚洲午夜高清视频| 卡一卡二国产精品| 久久国产欧美| 国产精品一区一区| 一区二区三区欧美在线| 亚洲毛片在线| 欧美~级网站不卡| 久久久久一区二区| 国产视频一区在线观看| 亚洲图片欧洲图片日韩av| 日韩视频在线永久播放| 免费在线观看一区二区| 蜜桃av久久久亚洲精品| 国产视频久久久久| 亚洲欧美综合国产精品一区| 亚洲在线视频观看| 欧美午夜视频在线| 日韩亚洲视频| 亚洲性线免费观看视频成熟| 欧美日韩国产成人精品| 亚洲精品国产精品国产自| 亚洲精品一区二区三区福利| 国产精品成人国产乱一区| 亚洲激情影视| 亚洲乱码国产乱码精品精| 欧美成人乱码一区二区三区| 欧美激情久久久久久| 亚洲三级国产| 欧美精品在线极品| 在线视频日韩精品| 亚洲欧美日韩一区二区三区在线 | 亚洲成人资源| 榴莲视频成人在线观看| 亚洲激情在线观看| 亚洲图片自拍偷拍| 国产精品国产精品国产专区不蜜| 一区二区三区|亚洲午夜| 亚洲欧美成人一区二区三区| 国产精品亚洲综合一区在线观看| 午夜久久福利| 欧美成人亚洲| 一区二区三区黄色| 国产精品亚洲欧美| 久久久夜精品| 日韩性生活视频| 久久久精品欧美丰满| 在线免费观看欧美| 欧美日韩国产色站一区二区三区| 亚洲综合成人婷婷小说| 欧美99久久| 亚洲免费伊人电影在线观看av| 国产尤物精品| 欧美激情在线播放| 午夜精品在线观看| 亚洲日本成人| 久久九九99| 99国产一区| 国产亚洲欧美另类一区二区三区| 欧美成年网站| 欧美一区免费视频| 亚洲精品久久久久久下一站 | 亚洲欧美日韩一区| 欧美激情网友自拍| 欧美一级艳片视频免费观看| 亚洲高清自拍| 国产欧美日韩三级| 欧美精品手机在线| 久久成人精品电影| 一区二区三区久久网| 美腿丝袜亚洲色图| 欧美一区二区三区在线视频| 亚洲精品在线观看视频| 国内精品一区二区| 欧美日韩综合| 欧美黄色片免费观看| 久久精品国语| 亚洲欧美日本在线| 99国内精品久久久久久久软件| 久久影院午夜论| 欧美一区二区精品久久911| 99在线观看免费视频精品观看| 狠狠狠色丁香婷婷综合激情| 国产精品福利在线观看| 欧美久久视频| 欧美xxx成人| 久久久一区二区| 欧美一区二粉嫩精品国产一线天| 夜夜精品视频| 一本色道久久综合亚洲精品高清| 欧美日韩成人在线| 一区二区三区波多野结衣在线观看|