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

雁過無痕

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::

《編程之美》讀書筆記072.5 尋找最大的K個數

 

問題:

n個數中找出最大的k個數。

 

兩種思路:

1 保存目前找到的最大k個數,每訪問一個數,就與這k個數中的最小值比較,決定是否更新這k個數。儲存k個數的數據結構可采用:敗者樹、二叉查找樹、最小堆。

C++ STL提供了multisetpriority_queue容器,另外還提供了make_heappush_heappop_heap方便手動構建堆結構。(測試發現,手工建堆的效率最高,當nk增大到一定值時,采用紅黑樹的multiset的效率極差。手動建堆的效率相比priority_queue有略微提高。)

 

2 修改排序方法,去除不必要的過程。

選擇排序: 只要選k次。

冒泡排序: 只要冒泡k次即可。

堆排序:   構建好最大堆后,取 k次最大值

快速排序: 分區時,根據數P將數組分為兩部分,設大于P的數個數為a,小于P的數的個數為b。如果,a>=k,則從這a個數取最大的k個數,若a<k,則從b個數取最大的k-a-1個。

歸并排序: 當待合并的兩個數組,兩數組長度和大等于k時,合并時只取前k個。或者:以(k+1)/2個數為一組,將數組分成幾個組,對每組進行排序(可以采用任何一種高效的排序方法)后,兩兩合并時只取前k個。

計數排序: 如果都是整數,先掃描一遍找出最大值max,最小值min,再掃一遍,將每個值減去min,對這個值計數,最后從max-min開始統計,找出最大的k個數。另外,也可采用桶排序。

桶排序:   可以不對桶內的數據進行排序。

基數排序: 可以采用最高關鍵字比較方法,并免去相關的排序。

 

STL中的nth_element就是基于對intorsort的修改(introtsort是對快速排序的改進,當遞歸深度達到一定值時,可切換到堆排序),而partial_sortpartial_sort_copy是基于堆排序的修改,因而在k很小時,其效率可能會高于nth_element。遺憾的是:STL沒有提供完全基于堆排序的nth_element

 

從下面的測試結果,可以看出:在M不是很大,M/N很小時,partial_sortpartial_sort_copy盡管多了“對堆結構進行排序”這個不必要的操作,其效率仍然高于nth_element,但相差不多。而在其它情況下nth_element的效率則比其它的幾種方法要高很多。

 

如果源數據都是整數,多數情況下(即使允許修改源數據),桶排序方法(結合計數方法)的效率比nth_element高。桶排序只需256K的內存,效率很高。在MN至少有一個大于當前內存大小的情況下,桶排序是最佳選擇,其性能遠高于其它方法。

 

如果源數據是浮點數,根據浮點數在內存中的表示,可以對桶排序方法進行適當修改,使之對浮點數也適用。

 

測試程序相關說明:

① 測試程序要求不得改變源數據,某些方法要多一個復制源數據操作,可以從partial_sort_copypartial_sort效率的差異,看出這個復制操作的影響。

② 桶排序方法對應nth_count

③ 對堆結構的調整,采用三種途徑(分別對應三個程序):利用push_heappop_heap、只用pop_heap、手寫代碼調整。(

multisetheapsort方法,在相同NM情況下,所用時間起伏很大,即所用時間對原始數據依賴性很高。

 

程序代碼

posted on 2010-08-16 00:02 flyinghearts 閱讀(2821) 評論(1)  編輯 收藏 引用 所屬分類: 編程之美

評論

# re: 《編程之美》讀書筆記07: 2.5 尋找最大的K個數 2014-08-12 13:59 121e1212
int test[][2] = {{5, 5}, {5, 7}, {7, 5}, {4, 4}, {4, 6}, {6, 4}};

const int sz = sizeof(test) / sizeof(test[0]);

std::cout << "Test 2:\n";http://www.ssnz88.net

for (int i = 0; i < sz; ++i) {

int row = test[i][0];

int col = test[i][1];

int **arr = new int*[row];

for (int i = 0; i < row; ++i) arr[i] = new int[col];
  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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麻豆的观看方式| 香蕉尹人综合在线观看| 99国产精品久久久久久久成人热| 久久五月激情| 牛夜精品久久久久久久99黑人| 久久久噜噜噜久久狠狠50岁| 久久婷婷激情| 欧美日韩你懂的| 国产亚洲午夜| 亚洲精品在线一区二区| 亚洲制服少妇| 免费成人你懂的| 99国产精品久久久久久久| 亚洲午夜久久久久久尤物| 欧美综合国产| 欧美激情中文字幕乱码免费| 国产精品久久久久久久午夜片| 国产日韩视频| 夜夜狂射影院欧美极品| 久久精品1区| 亚洲伦理在线| 久久精品九九| 国产精品v欧美精品v日本精品动漫 | 红桃视频国产精品| 99香蕉国产精品偷在线观看| 久久久精品久久久久| 亚洲高清视频在线观看| 一本色道久久综合亚洲精品高清| 欧美一区二区三区在线看| 欧美巨乳在线观看| 亚洲国产精品va在线观看黑人| 亚洲免费影视第一页| 欧美大秀在线观看| 久久国产精品99国产| 国产精品久久久久久久久免费桃花| 在线电影国产精品| 性欧美大战久久久久久久免费观看| 欧美国产在线观看| 欧美在线一级视频| 国产伦精品一区二区三区免费| 亚洲精品国产系列| 美脚丝袜一区二区三区在线观看 | 久久久久久夜精品精品免费| 国产精品萝li| 亚洲一区中文| 一本久久综合| 欧美日韩直播| 亚洲天堂男人| 一区二区三区高清不卡| 欧美日韩精品免费观看视频完整| 亚洲国产日韩精品| 欧美国产日韩一区| 美女脱光内衣内裤视频久久网站| 韩国久久久久| 欧美1区2区| 老鸭窝毛片一区二区三区| 黑人中文字幕一区二区三区| 国产精品老牛| 激情综合电影网| 久久久综合网| 性欧美精品高清| 国产一区二区精品| 久久久久久久波多野高潮日日| 亚洲欧美日韩高清| 国产一区在线视频| 欧美成人伊人久久综合网| 久久先锋影音| 日韩一级在线观看| 在线综合视频| 国产拍揄自揄精品视频麻豆| 久久久久久久久久久久久9999| 香蕉久久夜色| 亚洲激情社区| 一本色道综合亚洲| 国产日韩欧美一区在线| 巨乳诱惑日韩免费av| 欧美高清视频在线播放| 亚洲一区二区动漫| 欧美在线你懂的| 亚洲电影下载| 99热精品在线观看| 国户精品久久久久久久久久久不卡 | 欧美一区二区三区男人的天堂 | 欧美激情精品久久久久久免费印度| 在线欧美小视频| 最近中文字幕日韩精品| 国产精品久久一级| 男女激情视频一区| 国产精品久久久久aaaa九色| 久久精品1区| 欧美高清在线视频观看不卡| 欧美一级一区| 欧美成人在线影院| 久久国产精品亚洲va麻豆| 美女999久久久精品视频| 亚洲性av在线| 麻豆成人在线观看| 欧美+日本+国产+在线a∨观看| 一区二区三欧美| 欧美自拍偷拍午夜视频| 一区二区久久久久| 久久精品视频在线看| 亚洲一区二区精品在线| 久久久www免费人成黑人精品 | 亚洲欧美日韩在线| 亚洲精品美女久久7777777| 亚洲欧美中文另类| 99国产精品一区| 米奇777在线欧美播放| 久久精品亚洲| 在线日韩av片| 亚洲精品久久久蜜桃| 亚洲国产三级| 日韩亚洲欧美综合| 欧美亚洲网站| 99精品欧美| 麻豆视频一区二区| 久久久久久久久久看片| 国产精品盗摄久久久| 亚洲人成人77777线观看| 精品69视频一区二区三区| 亚洲一区二区高清| 亚洲一区二区三区中文字幕| 美女黄网久久| 欧美成年人视频| 激情欧美一区二区| 香蕉久久夜色精品| 欧美在线观看一区二区| 国产精品久久久久毛片软件| 亚洲最快最全在线视频| 一区二区三区四区国产| 欧美国产日本韩| 亚洲欧洲精品天堂一级| 亚洲蜜桃精久久久久久久| 免费一级欧美片在线观看| 老牛嫩草一区二区三区日本| 狠狠色噜噜狠狠色综合久| 久久久国产亚洲精品| 久久尤物视频| 亚洲国产一区二区三区a毛片| 久久免费的精品国产v∧| 久久免费视频在线观看| 黑人一区二区三区四区五区| 久久精品伊人| 欧美国产视频一区二区| 亚洲国产精品精华液2区45| 久久午夜精品一区二区| 欧美激情一区二区三区在线| 亚洲精品国产精品国自产在线| 免费在线视频一区| 日韩视频在线一区| 亚洲欧美日韩在线| 国产一区二区精品| 麻豆9191精品国产| 亚洲免费观看高清完整版在线观看熊| 在线亚洲精品| 国产日韩欧美日韩| 麻豆精品精品国产自在97香蕉| 亚洲国产精品女人久久久| 亚洲视屏一区| 狠狠色综合色综合网络| 能在线观看的日韩av| 99精品免费| 久久偷看各类wc女厕嘘嘘偷窃| 亚洲二区在线视频| 国产精品进线69影院| 久久香蕉国产线看观看av| 日韩视频在线观看国产| 久久精品91| 日韩视频中文| 国内精品免费在线观看| 欧美大尺度在线观看| 午夜国产精品视频免费体验区| 欧美.日韩.国产.一区.二区| 亚洲一区二区免费看| 一区视频在线播放| 国产精品黄页免费高清在线观看| 久久九九有精品国产23| 亚洲破处大片| 国产精品五月天| 欧美91视频| 欧美一区二区三区免费在线看| 亚洲国产成人在线播放| 午夜一区在线| 亚洲裸体俱乐部裸体舞表演av| 国产日本亚洲高清| 欧美人与性动交α欧美精品济南到 | 国产精品网站在线观看| 欧美精品18videos性欧美| 欧美在线观看天堂一区二区三区| 亚洲激情一区二区| 久久夜精品va视频免费观看| 亚洲女人av| 亚洲网在线观看| 亚洲最新在线视频| 亚洲免费高清| 亚洲精品国产系列| 亚洲国产精品专区久久|