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

隨筆-80  評論-24  文章-0  trackbacks-0
問題:一個大小為n的數組,里面的數有重復,要求找出數量超過一半的那個數。
傳統方法就不說了,排序然后順序掃描查找,復雜度為O(nlogn + n) = O(nlogn),有些慢。
《編程之美》上提供的方法是掃描數組,每次消去兩個不相同的數,這樣,到最后剩下的數必定是所求的數,證明非常簡單,略了。
關鍵問題是編碼,如果寫不好容易些成O(n2)復雜度的,書上的寫法不錯:

 1 int find_messager(int *id, int n) {
 2   assert(id != NULL);
 3   int i;
 4   int times = 1;
 5   int messager = id[0];
 6   for (i = 1; i < n; ++i) {
 7     if (times == 0) {
 8       messager = id[i];
 9       times = 1;
10     } else {
11       if (messager == id[i]) {
12         times++;
13       } else {
14         times--;
15       }
16     }
17   }
18   return messager;
19 }

擴展問題來了,如果有三個數,他們各自的總數都查過了n/4,那么怎么找出這三個數呢?
其實和上面解法類似,只不過是用三個標記就可以了,代碼如下:

 1 struct Messager {
 2   int id[4];
 3 };
 4                                                                                                                   
 5 Messager *find_messagers(int *id, int n) {
 6   assert(id != NULL);
 7   Messager *msgr = new Messager;
 8   memset(msgr, 0, sizeof(Messager));
 9   int times[4] = {0, 0, 0, 0};
10   int i, j;
11   for (i = 0; i < n; ++i) {
12     for (j = 1; j < 4; ++j) {
13       if (times[j] > 0 && msgr->id[j] == id[i]) {
14         times[j]++;
15         break;
16       }
17     }
18 
19     if (j == 4) {
20       for (j = 1; j < 4; ++j) {
21         if (times[j] == 0) {
22           times[j]++;
23           msgr->id[j] = id[i];
24           break;
25         }
26       }
27       if (j == 4) {
28         times[1]--;
29         times[2]--;
30         times[3]--;
31       }
32     }
33   }
34   return msgr;
35 }

這種思想非常清晰,并且實現非常巧妙!
posted on 2012-09-04 15:06 myjfm 閱讀(642) 評論(0)  編輯 收藏 引用 所屬分類: 算法基礎
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            性xx色xx综合久久久xx| 久久9热精品视频| 国产精品99久久久久久久女警| 久久天天躁夜夜躁狠狠躁2022| 午夜在线a亚洲v天堂网2018| 国产日韩欧美三区| 久久一日本道色综合久久| 久久爱另类一区二区小说| 国产亚洲成av人片在线观看桃| 久久精品二区亚洲w码| 久久国产精品久久国产精品| 在线观看一区二区精品视频| 欧美激情成人在线| 国产精品久久国产三级国电话系列| 午夜精品一区二区三区在线播放 | 韩国亚洲精品| 欧美激情一区二区| 欧美日韩美女| 久久久久久久久久久久久久一区 | 91久久精品日日躁夜夜躁欧美| 欧美岛国在线观看| 先锋影音国产一区| 久久综合色婷婷| 亚洲伊人久久综合| 久久米奇亚洲| 亚洲你懂的在线视频| 久久国产一区| 中文欧美在线视频| 久久精品夜色噜噜亚洲a∨| 日韩视频国产视频| 久久精品一区四区| 中文精品视频| 久久亚洲精品一区二区| 亚洲欧美国产精品专区久久| 久久久99久久精品女同性| 亚洲午夜激情网页| 久久综合九色综合久99| 午夜在线视频一区二区区别| 美日韩精品免费| 女同一区二区| 久久先锋影音av| 国产精品剧情在线亚洲| 亚洲大片一区二区三区| 国产视频综合在线| 亚洲视频大全| 99视频热这里只有精品免费| 久久一区精品| 久久精品中文字幕一区二区三区| 欧美日韩国产不卡在线看| 免费影视亚洲| 国产视频久久久久| 亚洲视频一区二区免费在线观看| 亚洲黄色在线观看| 久久久蜜桃精品| 久久精品免费| 国产日韩欧美中文| 亚洲在线播放| 性色av一区二区三区| 欧美日韩视频在线一区二区 | 亚洲国产精品高清久久久| 国内一区二区在线视频观看| 亚洲女人天堂av| 午夜精品久久一牛影视| 欧美日韩精品三区| 亚洲理论在线观看| 一本色道久久88精品综合| 欧美精品粉嫩高潮一区二区| 欧美高清在线一区| 亚洲看片免费| 欧美乱人伦中文字幕在线| 亚洲精品一区二区三区蜜桃久| 亚洲欧洲日本国产| 欧美精品一区二区三区四区| 亚洲激情视频| 亚洲最新视频在线| 欧美午夜在线一二页| 亚洲一区二区三区精品在线观看| 欧美一区二区免费视频| 国产欧美日韩综合一区在线播放| 午夜精品久久久久久久久久久久| 欧美一级片久久久久久久| 国产午夜精品视频| 久久综合国产精品| 亚洲激情在线观看视频免费| 夜久久久久久| 国产女精品视频网站免费| 欧美亚洲一级| 欧美激情一区二区三区在线| 亚洲九九精品| 国产精品无人区| 久久免费一区| 亚洲精品一区二区三区在线观看| 亚洲欧美日韩国产一区| 今天的高清视频免费播放成人 | 夜夜嗨网站十八久久| 亚洲欧美变态国产另类| 国产综合色在线| 欧美高清在线视频| 亚洲免费在线看| 欧美成人免费网| 亚洲午夜高清视频| 一区二区视频免费完整版观看| 欧美大片免费| 欧美在线在线| 99国产精品久久久久久久| 久久久一二三| 中国av一区| 在线成人黄色| 欧美成人黑人xx视频免费观看| 一区二区三区四区国产精品| 国内久久精品视频| 欧美日一区二区三区在线观看国产免| 亚洲欧美清纯在线制服| 亚洲第一免费播放区| 欧美一级精品大片| 99热在这里有精品免费| 国产伊人精品| 国产精品久久久久久福利一牛影视| 久久这里有精品视频| 亚洲专区欧美专区| 亚洲久久一区二区| 欧美刺激午夜性久久久久久久| 午夜亚洲激情| 亚洲视频电影图片偷拍一区| 在线免费观看视频一区| 国产日韩在线一区| 国产精品视频不卡| 欧美视频免费在线| 欧美日韩免费观看一区二区三区| 久久免费国产精品| 久久国产精品72免费观看| 亚洲综合二区| 这里只有精品丝袜| 99国产精品久久| 亚洲精品国产精品乱码不99| 欧美成人免费大片| 欧美 日韩 国产在线| 久久夜色精品亚洲噜噜国产mv | 亚洲成色精品| 国内精品国语自产拍在线观看| 国产精品无码永久免费888| 国产精品黄色| 国产精品久久二区二区| 欧美日韩网站| 欧美日韩亚洲综合一区| 欧美日韩无遮挡| 欧美色图一区二区三区| 欧美午夜久久| 国产精品毛片一区二区三区| 国产精品爱啪在线线免费观看| 欧美人与性动交a欧美精品| 欧美日韩成人激情| 国产精品久久久久久久久搜平片| 国产精品二区三区四区| 国产农村妇女精品一二区| 国产欧美一区二区色老头| 国产一区二区中文字幕免费看| 狠狠综合久久| 亚洲激情第一区| 一本大道久久精品懂色aⅴ| 亚洲一区尤物| 久久福利电影| 欧美va天堂va视频va在线| 亚洲国产99精品国自产| 亚洲精品免费一二三区| 亚洲手机在线| 久久精品国产一区二区三区| 免费久久99精品国产| 欧美精品九九99久久| 国产精品久久久久久久久动漫 | 欧美成人精品一区二区| 欧美人与性禽动交情品| 国产精品综合网站| 在线日韩中文字幕| 亚洲午夜一区二区三区| 久久久999成人| 亚洲精品视频免费在线观看| 亚洲欧美日韩国产精品| 久久全球大尺度高清视频| 欧美日韩免费观看中文| 国产综合在线视频| 一区二区三区日韩精品视频| 久久久久久久尹人综合网亚洲| 亚洲国产精品www| 亚洲欧美激情四射在线日| 欧美暴力喷水在线| 国产乱码精品一区二区三区五月婷 | 一二三四社区欧美黄| 亚洲尤物在线| 欧美www在线| 香蕉久久一区二区不卡无毒影院| 欧美aⅴ一区二区三区视频| 国产欧美日韩专区发布| 一区二区三区四区五区精品视频| 久久婷婷综合激情| 亚洲在线中文字幕| 欧美日韩国产一区二区| 亚洲第一在线综合在线| 欧美一级欧美一级在线播放| 亚洲黄色成人网|