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

posts - 183,  comments - 10,  trackbacks - 0

面試題 100 —— 5 查找 Top K

這里的做法是利用一個堆,用這個堆作為 K 個元素的輸出容器,堆的特點是可以以 O(1) 的效率去堆中最大/小的元素。
正式利用了這一點,這種方法的時間復(fù)雜度為 O(NlogK)

查找最小的 K 個數(shù)
利用最大堆
思路時,開始的時候堆為空,堆中元素個數(shù)還不足 K 個,所以遍歷的當(dāng)前元素直接加入到堆中
當(dāng)堆中元素等于 K 的時候,檢查當(dāng)前元素與堆中最大元素的大小關(guān)系,若大于最大元素則忽略,否則將堆中最大元素刪除,并將當(dāng)前元素添加到堆中。
整個過程,遍歷一遍集合,每次針對當(dāng)前元素需要對堆進行調(diào)整,總的時間復(fù)雜度為 O(NlogK)

http://www.shnenglu.com/jake1036/archive/2011/05/16/146466.html

代碼實現(xiàn):

 1 #include <iostream>
 2 #include <vector>
 3 #include <set>
 4 using namespace std;
 5 
 6 typedef vector<int> dataset;
 7 typedef multiset<int, greater<int> > bigheap;
 8 
 9 void findTopK(bigheap& bh, const dataset& ds, int k)
10 {
11  bh.clear();
12  for (dataset::const_iterator cit = ds.begin(); cit != ds.end(); ++cit)
13  {
14   if (bh.size() < k)
15   {
16    bh.insert(*cit);
17   }
18   else
19   {
20    bigheap::iterator it = bh.begin();
21    if (*it > *cit)
22    {
23     bh.erase(it);
24     bh.insert(*cit);
25    }
26   }
27  }
28 }
29 
30 int main()
31 {
32  dataset ds;
33  for (int i = 100; i != 0--i)
34  {
35   ds.push_back(i);
36  }
37  bigheap bh;
38  findTopK(bh, ds, 10);
39  for (bigheap::const_iterator cit = bh.begin(); cit != bh.end(); ++cit)
40  {
41   cout << *cit << endl;
42  }
43  return 0;
44 }
45 
46 


posted on 2011-07-12 17:46 unixfy 閱讀(316) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   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>
            日韩视频在线免费观看| 久久一区二区三区av| 一区二区三区四区五区精品| 欧美永久精品| 国产精品视频免费一区| 亚洲午夜成aⅴ人片| 亚洲片在线观看| 美女脱光内衣内裤视频久久影院| 国产欧美日韩在线视频| 亚洲欧美日韩成人| 亚洲视频一区在线观看| 国产精品porn| 午夜精品电影| 亚洲视频观看| 国产精品一区三区| 久久精品国产欧美亚洲人人爽| 一本色道久久综合亚洲精品不| 欧美精品在线观看一区二区| 99国产精品99久久久久久| 亚洲精品中文字幕女同| 欧美日韩亚洲一区| 亚洲欧美文学| 久久国产精品色婷婷| 亚洲高清久久| 亚洲人成在线影院| 国产精品成人一区二区艾草| 午夜亚洲性色视频| 久久aⅴ国产欧美74aaa| 亚洲高清自拍| 日韩视频专区| 国产香蕉97碰碰久久人人| 免费观看日韩av| 欧美巨乳波霸| 久久国产视频网站| 免费观看久久久4p| 中国成人在线视频| 欧美一区二区三区免费大片| 亚洲国产日韩欧美| 亚洲一级高清| 亚洲国产精品一区二区www| 日韩亚洲欧美成人| 国产一区二区三区四区五区美女 | 国产精品国产a| 久久精品30| 欧美成人嫩草网站| 欧美一区二区视频观看视频| 久久精品亚洲乱码伦伦中文| 日韩亚洲在线观看| 麻豆成人av| 91久久综合亚洲鲁鲁五月天| 欧美视频中文一区二区三区在线观看 | 欧美韩国一区| 久久精品72免费观看| 欧美激情精品久久久久久大尺度 | 亚洲激情社区| 国产日韩欧美综合| 91久久精品美女| 国产伦精品一区二区三区高清版| 欧美成人免费全部| 国产精品一区二区久久精品| 亚洲国产精品第一区二区三区| 国产欧美日韩综合精品二区| 亚洲激情综合| 亚洲电影欧美电影有声小说| 亚洲欧美日本国产有色| 在线视频亚洲| 欧美精品成人| 亚洲电影欧美电影有声小说| 国产综合色在线| 亚洲综合色自拍一区| 亚洲午夜在线观看视频在线| 美女脱光内衣内裤视频久久网站| 久久大香伊蕉在人线观看热2| 欧美日韩a区| 欧美高清视频一区二区| 国语对白精品一区二区| 午夜在线电影亚洲一区| 亚洲女同同性videoxma| 欧美色视频在线| 亚洲精品专区| 日韩午夜激情电影| 欧美激情一区二区三区全黄| 亚洲盗摄视频| 亚洲电影免费观看高清完整版在线观看 | 欧美电影免费| 影音先锋中文字幕一区二区| 午夜精品久久久| 欧美一区二区| 国产一区二区三区四区| 欧美一区二区三区免费视频| 午夜久久电影网| 国产欧美一区二区精品婷婷| 亚洲午夜av电影| 欧美亚洲一区| 国产在线观看一区| 久久青草久久| 欧美高清在线视频| 亚洲理论在线观看| 欧美日韩123| 亚洲一区二区精品| 午夜综合激情| 国产综合色产在线精品| 久久在线免费观看视频| 亚洲电影免费| 亚洲午夜久久久| 国产精品视频内| 久久国产欧美日韩精品| 免费观看国产成人| 99视频热这里只有精品免费| 亚洲福利视频网站| 99re国产精品| 一片黄亚洲嫩模| 国产精品视频不卡| 久久经典综合| 亚洲精品1区2区| 亚洲欧美日韩国产综合在线| 国产亚洲精品bt天堂精选| 久久久久久久久久看片| 亚洲国内精品| 欧美一区二区高清| 极品少妇一区二区三区| 欧美另类综合| 亚洲资源av| 欧美激情网友自拍| 午夜精品久久久久久久白皮肤| 国内成人精品一区| 欧美区二区三区| 欧美影院精品一区| 99精品欧美一区| 久久午夜视频| 亚洲少妇一区| 亚洲第一在线综合在线| 国产精品久久波多野结衣| 久久婷婷人人澡人人喊人人爽| 91久久精品国产91久久性色| 久久精品123| 亚洲视频二区| 亚洲高清久久久| 国产视频一区在线观看| 欧美日韩国产一中文字不卡| 久久精品盗摄| 亚洲一区二区三区激情| 亚洲国产va精品久久久不卡综合| 亚洲欧美中日韩| 日韩视频在线播放| 激情小说另类小说亚洲欧美| 欧美性猛交99久久久久99按摩| 久久先锋资源| 久久激情网站| 欧美一级黄色录像| 一本一本久久a久久精品综合麻豆| 欧美大片在线观看| 久久性天堂网| 久久精品国产69国产精品亚洲| 一区二区日韩伦理片| 亚洲精品国产欧美| **网站欧美大片在线观看| 国产一区二区精品久久| 国产精品一二三四区| 欧美日韩性视频在线| 欧美成人一区二区三区| 美女黄色成人网| 久久色中文字幕| 久久露脸国产精品| 校园春色综合网| 欧美一区二区三区四区夜夜大片| 亚洲性感激情| 亚洲一区二区三区高清 | av不卡在线| 亚洲精品久久久久久一区二区| 欧美激情第二页| 欧美韩日一区二区| 欧美成人午夜激情| 亚洲第一精品影视| 欧美激情第4页| 亚洲高清影视| 亚洲人成在线免费观看| 亚洲精品免费观看| 亚洲免费观看在线观看| 亚洲精品女人| 欧美黄色片免费观看| 亚洲大胆人体视频| 亚洲国产精品福利| 欧美一区二区视频在线观看| 国产精品在线看| 国产午夜久久久久| 精品成人一区二区三区四区| 国产亚洲综合精品| 一区二区三区我不卡| 亚洲黄色免费| 亚洲视频在线免费观看| 亚洲欧美另类久久久精品2019| 亚洲综合成人婷婷小说| 欧美一区二视频| 麻豆精品视频在线观看| 欧美国产成人在线| 中日韩在线视频| 香蕉亚洲视频| 久热精品视频| 欧美精品一区二区三区久久久竹菊 |