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

posts - 4,  comments - 27,  trackbacks - 0
問題:
      原題叫“尋找發帖王”,其實就是在n個數里,存在一個數x,出現頻率超過n/2的數,要以最小的時間復雜度計算出這個x。

動機:
      這個題目是昨晚無聊時,在CSDN論壇上看到的,起初我是這樣想的:既然有個數x出現頻率超過n/2,那如果排好序,那么第[n/2]個數一定就是x。這 樣問題就規約為這樣一個問題:“計算一組數的中位數”。《算法導論》有提出過解決辦法,就是類似快速排序那樣,使用分治算法,在O(n)復雜度內解決問 題。但算法性能依賴于數據的分布,最壞情況會達到O(n2)。
      后來在網上搜了一下,發現這居然是《編程之美》上的。記得當初上大學的時候,我還看過,可怎么也想不起來了。看到書上提到的算法,不禁黯然稱奇!于是產生了個想法,我決定重新看一遍,并且寫一個系列的博客,寫下自己的心得。

引理:
      n個數中,數x出現頻率超過n/2,那么從中去掉一對不相等的兩個數,x在剩下的(n-2)個數中的出現頻率依然超過n/2。

證明:
      假設x出現了m次,則m > n/2,原頻率P0 = m/n > 1/2,從n個數中去掉一對不相同的兩個數<a, b>,有兩種情況:
  1. a != x, b != x。頻率P1 = m/(n-2) > m/n > 1/2
  2. a = x, b != x。 頻率P1 = (m - 1)/(n - 2)。P1 - P0 = (2m - n)/n(n - 2) > 0。則 P1 > P0 > 1/2

算法分析:

      其實說到底非常簡單,就是在一堆數里隨便拿一個數,再找一個與它不相等的,然后一起扔掉,這樣問題規模不斷縮小,最終等到找不到一個不相等的數時,就成功 了。但要簡化算法,就不能每拿一個數就統統找一遍。可以考慮準備一個隊列,隊列里放著暫時扔不掉的數。如從頭開始,將a[0]放入隊列,再看a[1],如 果a[0] != a[1],則扔掉a[1]和a[0],a[0]從隊列取出;如果a[0] == a[1],則a[1]入隊列,然后a[2]進行相同的操作,以此類推。

      解法依然可以優化。顯而易見,隊列里所有的數總是全部相等的,既然相等就沒有必要存入隊列,只要知道:1.假想的隊列里的數什么 2.隊列的長度。

      這樣就得到了《編程之美》中的代碼了:

 1 int data_more_than_half(const int arr[], const size_t size) {
 2     int candidate;
 3     int count = 0;
 4 
 5     for(size_t i = 0; i < size; i++) {
 6         if (count == 0) {
 7             candidate = arr[i];
 8             count = 1;
 9         }
10         else {
11             if (candidate == arr[i]) {
12                 count++;
13             }
14             else {
15                 count--;
16             }
17         }
18     }
19     return candidate;
20 }


應用:

      代碼看似簡單,但我感到意猶未盡,正回味著,突然想到一個問題:如果條件(存在一個出現頻率超過一半的數)不滿足,那會出現什么情況?如何避免呢?

      很顯然,我們的解法就是基于這樣一個條件的,一旦條件不滿足,得到的數就沒有任何意義。但不難發現,避免問題的出現也非常簡單:驗證找到的數是否出現頻率超過一半。

      這也是個常用的方法:假設檢驗法。

      對于一個數組,假設存在一個數,它出現頻率超過一半。然后在O(n)時間內找到這個數,再統計它出現的頻率。這樣就完美了!

      于是可以得到一個同解的跳躍式問題:檢查一個數組中,是否存在一個數,它出現頻率超過一半。

posted on 2012-05-23 00:39 夜風 閱讀(2341) 評論(4)  編輯 收藏 引用 所屬分類: 編程之美心得

FeedBack:
# re: 編程之美----尋找出現頻率超過一半的數[未登錄]
2012-05-23 09:31 | ithaca
看來你還沒整明白count是干什么用的。。。  回復  更多評論
  
# re: 編程之美----尋找出現頻率超過一半的數[未登錄]
2012-05-23 13:16 | yefeng
@ithaca
我的解釋有什么問題嗎?  回復  更多評論
  
# re: 編程之美----尋找出現頻率超過一半的數[未登錄]
2012-05-23 14:34 | 春秋十二月
在《算法引論》中查找眾數一節,講解了這種線性時間算法的實現,不管眾數是否存在。提個小問題,P1 - P0 = (2m - n)/n(n - 1) > 0,分母應該是n(n-2)吧  回復  更多評論
  
# re: 編程之美----尋找出現頻率超過一半的數[未登錄]
2012-05-23 19:42 | yefeng
@春秋十二月
手誤,確實是n(n-2)  回復  更多評論
  
<2009年10月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

常用鏈接

留言簿(1)

隨筆分類(7)

隨筆檔案(4)

文章分類

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 国产精品一区毛片| 在线中文字幕日韩| 欧美高清不卡| 久久综合给合| 亚洲色图在线视频| 亚洲理伦电影| 欧美插天视频在线播放| 在线精品国产欧美| 久久亚洲私人国产精品va媚药| 亚洲午夜一区二区三区| 欧美日韩黄色大片| 宅男在线国产精品| 久久精品官网| 亚洲一区免费| 亚洲一级特黄| 尤妮丝一区二区裸体视频| 亚洲精品乱码久久久久久| 欧美国产第二页| 日韩网站在线观看| 久久成人免费视频| 亚洲图片自拍偷拍| 久久野战av| 亚洲日本成人| 免费在线成人av| 蜜桃av综合| 99ri日韩精品视频| 欧美在线1区| 亚洲电影天堂av| 亚洲自拍另类| 亚洲综合欧美日韩| 欧美日韩国产色综合一二三四| 久久综合久久综合久久| 国产精品免费福利| 久久精品男女| 国产精品成人aaaaa网站| 一区二区三区欧美日韩| 久久嫩草精品久久久精品一| 欧美一区二区三区的| 久久精品一区| 99综合视频| 欧美成人激情视频| 欧美激情视频网站| 亚洲第一区在线观看| 久久久精品午夜少妇| 久久噜噜噜精品国产亚洲综合| 久久一区二区三区国产精品 | 国产一区二区三区久久久| 亚洲国产精品高清久久久| 欧美视频日韩视频| 亚洲精品小视频在线观看| 亚洲精品视频在线播放| 美女视频一区免费观看| 蜜桃av一区二区在线观看| 精品成人一区二区| 一本色道久久综合亚洲二区三区| 国内久久视频| 一区二区欧美激情| 亚洲一区二区三区四区在线观看| 日韩亚洲欧美中文三级| 亚洲欧美一区二区在线观看| 伊人久久综合97精品| 久久精品国产77777蜜臀| 久久精品国产久精国产思思| 国内外成人免费激情在线视频 | 欧美成年网站| 最新成人在线| 欧美三级视频在线| 亚洲素人一区二区| 久久久久综合一区二区三区| 在线看片第一页欧美| 欧美 日韩 国产 一区| 久久精品国产久精国产一老狼| 国产一区二区成人| 欧美国产日本| 亚洲宅男天堂在线观看无病毒| 久久蜜桃av一区精品变态类天堂| 亚洲激情电影在线| 久久久精品国产免费观看同学| 欧美成人日韩| 亚洲一区二区三区欧美| 国产午夜精品美女视频明星a级| 亚洲精品专区| 欧美在线看片| 国产一区二区三区在线播放免费观看| 久久爱www久久做| 亚洲国产天堂网精品网站| 亚洲欧美精品在线观看| 欧美日韩免费观看一区二区三区| 亚洲高清av在线| 香蕉乱码成人久久天堂爱免费| 国产精品草草| 久久久久久久综合日本| 久久这里只有精品视频首页| 日韩视频在线永久播放| 国产午夜亚洲精品不卡| 欧美精品在线观看| 久久精品国产视频| 一本一本久久| 亚洲黄色一区二区三区| av成人免费| 伊人天天综合| 国产精品一区二区女厕厕| 欧美岛国激情| 久久免费国产精品| 亚洲一区二区高清视频| 久久久久一区| 午夜国产精品影院在线观看| 国产三级欧美三级| 欧美日韩国产色综合一二三四| 久久视频在线免费观看| 午夜精品久久一牛影视| 99av国产精品欲麻豆| 午夜视黄欧洲亚洲| 宅男噜噜噜66一区二区66| 91久久久在线| 亚洲国产成人精品女人久久久| 欧美激情久久久| 久久久久**毛片大全| 午夜在线观看免费一区| 欧美国产一区视频在线观看| 欧美在线免费看| 欧美一区永久视频免费观看| 亚洲欧美日韩爽爽影院| 亚洲一区二区欧美日韩| 一本色道久久综合一区| 日韩视频永久免费| 国产日韩欧美成人| 国产午夜精品久久| 国产欧美一区二区三区久久| 麻豆精品国产91久久久久久| 欧美一区二区三区在线观看视频| 久久在线视频在线| 亚洲精品你懂的| 韩国一区电影| 国产亚洲一区精品| 国产精品第三页| 欧美四级在线| 国产精品久久久久国产精品日日| 欧美日韩成人一区二区| 欧美激情在线播放| 亚洲人被黑人高潮完整版| 蜜桃久久av| 欧美成人三级在线| 欧美激情一区二区三区| 亚洲麻豆国产自偷在线| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 欧美日韩一区二区三区免费看| 欧美日韩免费观看中文| 国产精品久久久久久久久免费桃花 | 欧美专区在线播放| 久久久久久久尹人综合网亚洲| 久久亚洲精品网站| 欧美精品videossex性护士| 欧美日本在线| 国产精品女同互慰在线看| 国产一区清纯| 亚洲精品视频一区| 亚洲欧美美女| 欧美mv日韩mv国产网站| 亚洲精品一区二区三区在线观看| 亚洲午夜影视影院在线观看| 久久日韩精品| 欧美午夜宅男影院| 伊人色综合久久天天| 亚洲一区二区三区高清 | 欧美一级专区| 欧美α欧美αv大片| av成人手机在线| 亚洲免费观看| 欧美一区二区在线观看| 欧美极品欧美精品欧美视频| 国产欧亚日韩视频| 99精品国产99久久久久久福利| 午夜久久美女| 亚洲品质自拍| 久久久久成人网| 国产精品久久久久久久久借妻 | 国产在线日韩| 亚洲综合色视频| 亚洲第一页中文字幕| 欧美一区二区三区日韩| 欧美日韩一区二区三区在线看 |