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

posts - 183,  comments - 10,  trackbacks - 0

在已排序數組中查找出現最多的數字
http://www.vanjor.org/blog/2011/04/puzzle-array-find-most/

這里有個前提是數組已排好序
如果出現最多的數字出現次數大于一般,那么這個出現次數最多的數字就是位于數組中中間位置的數,這里需要考慮數組中的元素個數是奇數還是偶數
出現次數最多的數字的出現次數是大于元素數目的一般

如果數組是未排序的情況呢?
可以先把數組排好序,然后再把按照已排序的情況處理
也可以不排序,直接處理,這種情況下某個數的出現次數大于元素數目的一般比較好解決

1.
這里要解決的第一個問題是:
·已排序
·查找出現最多的數字,這個數字的出現次數不一定大于所有元素數目的一半
時間復雜度是 O(N)
程序:

 1 #include <iostream>
 2 #include <vector>
 3 using namespace std;
 4 
 5 bool isSorted(const vector<int>& data)
 6 {
 7     for (vector<int>::size_type i = 0; i != data.size() - 1++i)
 8     {
 9         if (data[i + 1< data[i])
10         {
11             return false;
12         }
13     }
14     return true;
15 }
16 
17 int findMaxTimesNumber(const vector<int>& data)
18 {
19     if (data.size() <= 0)
20     {
21         return -10000;
22     }
23     int count = 0;
24     int recorder = data[0];
25     int times = 1;
26     count = times;
27     for (vector<int>::size_type i = 1; i != data.size(); ++i)
28     {
29         if (data[i] == data[i - 1])
30         {
31             ++times;
32         }
33         else
34         {
35             if (times > count)
36             {
37                 count = times;
38                 recorder = data[i - 1];
39             }
40             times = 1;
41         }
42     }
43     if (times > count)
44     {
45         count = times;
46         recorder = data[data.size() - 1];
47     }
48     return recorder;
49 }
50 
51 int main()
52 {
53     vector<int> data;
54     int n;
55     while (cin >> n)
56     {
57         data.push_back(n);
58     }
59     if (!isSorted(data))
60     {
61         cerr << "Error!" << endl;
62         return 1;
63     }
64     cout << findMaxTimesNumber(data) << endl;
65 }


===
這種解法本質上并不要求數組是已排好序的
只是要求相等的數字必須是在一起連續的

2.
第二種情況
數組是已排好序的,并且有一個數字出現次數大于數組中元素的總數目
時間復雜度:O(1)
如果總數目是奇數:

 

int foo(const vector<int>& data)
{
    
return data[data.size() / 2];
}


出現次數必須大于一半

如果總數目是偶數:

 

int foo(const vector<int>& data)
{
    
return data[data.size() / 2];
}


出現次數必須大于一半,其大小情況不必有嚴格要求,因為只要次數大于一半,該出現最多的數字一定是中間的那個 data[data.size() / 2]

3.
第三種情況
不是未排序的數組
但是有一個數字的出現次數大于數組元素數目的一半
時間復雜度:O(N)

 

 1 #include <iostream>
 2 #include <vector>
 3 using namespace std;
 4 
 5 int findMaxTimesNumber(const vector<int>& data)
 6 {
 7     if (data.size() <= 0)
 8     {
 9         return -10000;
10     }
11     int ret = data[0];
12     int count = 1;
13     for (vector<int>::size_type i = 1; i != data.size(); ++i)
14     {
15         if (data[i] == ret)
16         {
17             ++count;
18         }
19         else
20         {
21             --count;
22             if (count == 0)
23             {
24                 count = 1;
25                 ret = data[i];
26             }
27         }
28     }
29     if (count > 1)
30     {
31         return ret;
32     }
33     else
34     {
35         return -10000;
36     }
37 }
38 
39 int main()
40 {
41     vector<int> data;
42     int n;
43     while (cin >> n)
44     {
45         data.push_back(n);
46     }
47     cout << findMaxTimesNumber(data) << endl;
48     return 0;
49 }


posted on 2011-12-29 12:29 unixfy 閱讀(1152) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日本久久| 亚洲自拍偷拍视频| 亚洲永久免费精品| 亚洲影院免费观看| 亚洲免费婷婷| 久久国产视频网站| 久久亚洲不卡| 欧美激情亚洲精品| 亚洲精品乱码久久久久久| 欧美激情女人20p| 亚洲美女色禁图| 欧美亚洲日本国产| 老牛影视一区二区三区| 欧美日韩精品一区视频| 国产日韩欧美在线播放| 亚洲国产电影| 亚洲专区欧美专区| 女女同性精品视频| 亚洲视频在线二区| 久久一区二区三区四区| 国产精品美女久久| 亚洲高清久久久| 亚洲欧美日韩电影| 欧美激情亚洲精品| 欧美一区亚洲| 欧美日韩视频在线| 在线免费观看视频一区| 亚洲视频精选在线| 美日韩在线观看| 亚洲一区二区高清视频| 免费黄网站欧美| 国产一区二区0| 亚洲午夜精品国产| 亚洲电影在线观看| 欧美自拍丝袜亚洲| 国产精品久久网站| 99综合精品| 黄色成人av网站| 亚洲少妇中出一区| 欧美国产日韩a欧美在线观看| 亚洲视频在线二区| 欧美日韩亚洲视频一区| 91久久线看在观草草青青| 久久精品视频免费观看| 亚洲一区三区视频在线观看| 欧美日韩精品久久| 日韩视频免费大全中文字幕| 欧美1区3d| 久久综合伊人77777麻豆| 黑人巨大精品欧美一区二区| 久久精品国产亚洲aⅴ| 亚洲一区在线观看免费观看电影高清| 免费视频一区二区三区在线观看| 国产亚洲欧美激情| 久久xxxx| 午夜精品免费在线| 国产欧美精品在线播放| 先锋a资源在线看亚洲| 亚洲视频欧洲视频| 国产精品久久久久影院色老大 | 国产精品久久久免费| 亚洲中无吗在线| 亚洲综合社区| 国产一区二区欧美日韩| 欧美在线一级va免费观看| 亚洲欧美日韩天堂| 国产午夜精品全部视频播放 | 亚洲影音一区| 国产精品综合久久久| 欧美一区二区三区久久精品茉莉花| 中日韩高清电影网| 国产欧美日韩综合| 久久午夜电影| 男女精品网站| 亚洲视屏在线播放| 亚洲一区二区三区免费在线观看| 国产精品人人做人人爽人人添| 午夜久久99| 久久久久久久91| 亚洲人成精品久久久久| 99re热精品| 国产日韩欧美不卡在线| 美女精品一区| 欧美日韩在线另类| 久久久久久日产精品| 奶水喷射视频一区| 午夜精品久久久久久久久久久| 久久精品盗摄| 一本色道88久久加勒比精品| 亚洲欧美日本另类| 在线欧美视频| 在线视频精品| 在线观看欧美激情| 一区二区日韩欧美| 欧美大尺度在线| 亚洲欧美国产高清| 久久综合九色综合久99| 亚洲伊人伊色伊影伊综合网| 久久精品亚洲精品| 亚洲色在线视频| 久久中文字幕一区| 欧美伊人精品成人久久综合97| 你懂的成人av| 久久午夜羞羞影院免费观看| 国产精品久久久久久久久借妻| 欧美成年人网站| 国产欧美精品| 99精品视频免费观看| 悠悠资源网亚洲青| 亚洲欧美国产va在线影院| 99精品国产高清一区二区| 校园激情久久| 亚洲欧美日韩在线高清直播| 欧美大秀在线观看| 久久综合伊人77777蜜臀| 国产精品久久久久久久9999| 亚洲精品视频免费观看| 亚洲每日更新| 美女主播一区| 免费的成人av| 精品91在线| 欧美主播一区二区三区美女 久久精品人 | 在线观看一区二区视频| 亚洲免费视频观看| 亚洲伊人一本大道中文字幕| 欧美精品在线一区| 亚洲大片免费看| 亚洲第一精品久久忘忧草社区| 午夜在线视频观看日韩17c| 午夜亚洲伦理| 国产欧美日韩视频一区二区三区 | 亚洲在线免费| 欧美丝袜第一区| 亚洲婷婷综合久久一本伊一区| 亚洲天堂偷拍| 国产精品v欧美精品∨日韩| 99av国产精品欲麻豆| 亚洲一区二区三区四区中文| 欧美日韩一区成人| 99在线热播精品免费99热| 亚洲无线观看| 国产精品国产三级国产专播品爱网 | 亚洲永久精品大片| 国产精品电影观看| 亚洲一区二区三区免费视频| 欧美在线亚洲在线| 黄色在线一区| 欧美阿v一级看视频| 亚洲精品免费电影| 亚洲一区成人| 国产亚洲综合性久久久影院| 久久视频在线看| 欧美成人资源网| 国产伦精品一区二区三区高清版| 亚洲午夜电影网| 欧美亚洲免费在线| 国产一二精品视频| 久热成人在线视频| 亚洲精品免费一区二区三区| 99国产精品99久久久久久粉嫩 | 欧美视频在线观看 亚洲欧| 亚洲视频观看| 久久久一区二区| 日韩一级精品视频在线观看| 国产精品美女久久久久久免费 | 亚洲精品乱码久久久久久黑人| 亚洲色诱最新| 伊人成人开心激情综合网| 欧美精品少妇一区二区三区| 一本色道久久综合| 玖玖玖国产精品| 一区二区三区四区精品| 国内成人精品2018免费看| 欧美日韩国产999| 久久久久国产一区二区| 99视频精品全国免费| 久久亚洲免费| 亚洲午夜在线| 亚洲成色777777女色窝| 国产精品美女久久久浪潮软件| 久久久国产成人精品| 一区二区三区欧美成人| 欧美激情第三页| 久久精品毛片| 亚洲综合视频在线| 亚洲免费观看在线观看| 激情久久五月| 国产精品一区视频网站| 欧美三级在线播放| 欧美激情一区二区| 麻豆精品精华液| 久久久噜噜噜久久中文字幕色伊伊| 在线视频欧美日韩| 99国内精品久久| 91久久极品少妇xxxxⅹ软件| 蜜桃视频一区| 农夫在线精品视频免费观看| 久久亚洲视频| 老牛国产精品一区的观看方式| 欧美亚洲一区二区三区|