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

coding everyday

編程面試題 https://interview.codeplex.com

C++博客 首頁 新隨筆 聯系 聚合 管理
  12 Posts :: 2 Stories :: 7 Comments :: 0 Trackbacks
本題目出自@陳利人

問題:
#Google面試題#給你一天的Google搜索日志,你怎么設計算法找出是否有一個搜索詞,它出現的頻率占所有搜索的一半以上?如果肯定有一個搜索詞占大多數,你能怎么提高你的算法找到它?再假定搜索日志就是內存中的一個數組,能否有O(1)空間,O(n)時間的算法?

剛看到這個題目的時間嚇壞了,好難啊,無從下手啊,為自己的之上捉急啊。。下班的班車上開始想這個問題,開始分析,其實這個搜索日志就是一個搜索詞的集合嘛,甭管它有多大,總可以分成若干堆吧。既然這個搜索詞超過一半,那么在這若干堆中分別找出來最流行的詞中,也應該占一半吧。(這個應該沒有理解錯吧。)

這個時候我想可以把問題轉換成一個整數數組,其中有個整數出現的次數超過一半,找出這個整數就OK了吧。要找出這個數組中出現次數超一半的值,本身這個算法應該很簡單,但是O(1)空間和O(n)的時間復雜度,還是有點傷腦筋的。。:(,內存又不貴,為啥O(1)啊。。

因為那個數字出現的次數超過一半,我們可以想象一下,把那個數字標成1,其它的都是-1,把所有的數字加起來肯定大于0,對吧?因為超過一半嘛。。這個時候靈光乍現,用一個標桿來標志潛在的那個搜索詞,一個整數count表示它出現的次數(準確的說不是它的次數,后面會解釋),遍歷整個數組
1)   如果當前的跟標桿一樣,count++
2)   如果不相等,--count,若此時count為0,則把當前值置為標桿,count為1
重復1), 2)即可,最后那個標桿即為最流行搜索詞。

代碼簡單的我不能相信,以至于我覺得我肯定理解錯誤題目的意思了,不管怎么樣上下代碼 
 1 // Get the most popular searching keyword in Google. :)
 2 template<typename T>
 3 T get_most_popular_keyword(const T *list, int size) {
 4     T result = list[0];
 5     int count = 0;
 6 
 7     for (int i=0; i<size; i++) {
 8         if (list[i] == result)
 9             count++;
10         else {
11             if (--count == 0) {
12                 count = 1;
13                 result = list[i];
14             }
15         }
16     }
17 
18     return result;
19 }
posted on 2013-07-02 21:10 everyday 閱讀(365) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            99精品视频免费| 国产精品午夜av在线| 亚洲人成在线观看网站高清| 久久天天躁狠狠躁夜夜爽蜜月| 亚洲影院色无极综合| 亚洲在线电影| 欧美在线1区| 美女精品在线| 亚洲国产精品久久| 99国产精品久久久久久久成人热| 99在线视频精品| 性欧美在线看片a免费观看| 久久久久久久91| 欧美黑人国产人伦爽爽爽| 欧美日本中文字幕| 国产欧美一区二区精品秋霞影院| 精品电影一区| 在线亚洲+欧美+日本专区| 欧美一区二区三区视频在线 | 在线免费精品视频| 亚洲精一区二区三区| 午夜精品一区二区三区四区 | 亚洲作爱视频| 校园春色综合网| 久久综合九色| 一区二区三区欧美视频| 欧美主播一区二区三区| 免费日韩av片| 国产精品日韩一区二区三区| 在线观看中文字幕不卡| 亚洲欧美美女| 亚洲国产一区在线观看| 欧美在线视频一区| 欧美日韩在线播放一区| 在线看欧美视频| 欧美一区二区精品| 亚洲日本aⅴ片在线观看香蕉| 欧美一级电影久久| 欧美视频在线观看| 亚洲免费电影在线观看| 欧美国产在线电影| 久久久久久亚洲精品中文字幕| 国产精品欧美久久| 中文精品一区二区三区 | 一本色道久久综合亚洲精品高清| 久久久国产91| 国产手机视频一区二区| 亚洲自拍16p| 日韩一区二区电影网| 欧美国产一区二区| 91久久国产综合久久91精品网站| 久久久久久一区二区| 亚洲一区二区精品视频| 欧美日韩在线观看视频| 99re成人精品视频| 亚洲精品日韩激情在线电影| 欧美黄色影院| 日韩亚洲欧美在线观看| 亚洲肉体裸体xxxx137| 欧美二区在线播放| 99视频一区二区三区| 亚洲黄色成人久久久| 欧美成人视屏| 中文亚洲欧美| 亚洲一区一卡| 国产欧美日韩亚洲一区二区三区| 欧美一区二区三区免费视| 亚洲欧美日韩精品一区二区 | 欧美视频在线免费看| 亚洲视频网在线直播| 一区二区三区av| 国产精品日韩专区| 久久久精彩视频| 久久手机精品视频| 亚洲国产综合在线| 亚洲精品乱码| 国产精品不卡在线| 久久精品国产免费| 久久久精品久久久久| 国产精品99一区二区| 欧美人与禽猛交乱配视频| 亚洲欧洲一区二区三区| 亚洲精品乱码久久久久| 国外成人在线| 在线播放日韩| 欧美综合二区| 亚洲巨乳在线| 国产精品久久久91| 国产欧美日韩激情| 久久免费黄色| 欧美高清视频在线| 亚洲欧美综合精品久久成人| 亚洲综合色视频| 亚洲大胆在线| 亚洲一区二区三区色| 亚洲高清在线| 亚洲男女自偷自拍图片另类| 91久久夜色精品国产九色| 宅男噜噜噜66一区二区 | 在线中文字幕一区| 狠狠久久亚洲欧美| 99在线精品观看| 在线观看日韩精品| 在线视频欧美日韩精品| 亚洲国产精品欧美一二99| 亚洲在线视频一区| 日韩午夜免费| 欧美有码在线视频| 亚洲一区二区不卡免费| 麻豆精品视频在线观看| 欧美一区二区三区播放老司机| 欧美精选一区| 免费亚洲电影在线观看| 国产精品男女猛烈高潮激情 | 另类尿喷潮videofree| 亚洲午夜电影| 免费日韩视频| 美女精品在线| 一区二区三区自拍| 欧美亚洲视频一区二区| 亚洲综合日韩| 欧美日韩调教| 亚洲国产精品成人综合| 国产亚洲电影| 午夜免费久久久久| 午夜欧美精品| 欧美日韩综合视频网址| 亚洲国产一区二区三区青草影视| 激情自拍一区| 久久久999精品视频| 久久精品99国产精品日本| 国产精品国产| 亚洲午夜久久久久久久久电影网| 9久re热视频在线精品| 亚洲欧洲一区二区在线观看| 欧美人成在线视频| 最新国产乱人伦偷精品免费网站| 亚洲第一精品久久忘忧草社区| 性伦欧美刺激片在线观看| 欧美一区二区黄| 国产精品亚洲综合久久| 亚洲一区免费看| 久久精品最新地址| 狠狠色狠狠色综合人人| 久久久久久久久岛国免费| 美腿丝袜亚洲色图| 亚洲黄色成人网| 欧美精品久久99| 99热这里只有精品8| 欧美一区二区三区男人的天堂 | 亚洲国产高清一区二区三区| 久久看片网站| 亚洲三级观看| 亚洲午夜激情网站| 国产女主播一区二区| 欧美在线日韩| 亚洲区在线播放| 亚洲综合国产激情另类一区| 国产亚洲二区| 欧美激情中文字幕一区二区| 一本一本大道香蕉久在线精品| 亚洲欧美成人一区二区在线电影 | 亚洲欧美一区二区精品久久久| 久久久久女教师免费一区| 亚洲国产欧美一区二区三区久久 | 亚洲国产精品一区二区www在线| 欧美成人嫩草网站| 亚洲欧美另类国产| 欧美激情第8页| 亚洲一级在线观看| 在线观看国产欧美| 国产精品99免视看9| 久久久久久久波多野高潮日日| 亚洲人成人77777线观看| 亚洲综合国产激情另类一区| 国内一区二区在线视频观看| 欧美日本乱大交xxxxx| 久久国产毛片| 亚洲少妇中出一区| 亚洲电影专区| 久久天天躁狠狠躁夜夜av| 亚洲永久精品国产| 91久久在线播放| 国产一区二区三区在线观看精品 | 久久精品导航| 日韩午夜电影| 免费亚洲婷婷| 久久成人在线| 亚洲性夜色噜噜噜7777| 亚洲国内精品在线| 国产一区二区三区久久久| 在线视频免费在线观看一区二区| 久久精品理论片| 99精品久久久| 在线观看三级视频欧美| 国产精品欧美久久久久无广告| 欧美大片在线观看一区| 久久国产精品毛片| 亚洲欧美韩国| 亚洲午夜精品福利|