亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

STl中的排序算法詳細解析

2020-02-24 14:25:06
字體:
來源:轉載
供稿:網友

STL?算法提供了很多有用的算法和操作,從簡單到復雜到穩定排序,也需要保持高效,下面武林技術頻道小編就帶大家一起來了解一下STl中的排序算法詳細解析,希望能幫到大家。

1. 所有STL sort算法函數的名字列表:

函數名???          功能描述

sort        ? 對給定區間所有元素進行排序

stable_sort     對給定區間所有元素進行穩定排序

partial_sort     對給定區間所有元素部分排序

partial_sort_copy??? 對給定區間復制并排序

nth_element     找出給定區間的某個位置對應的元素

is_sorted?????????????? 判斷一個區間是否已經排好序

partition     ??? 使得符合某個條件的元素放在前面

stable_partition????? 相對穩定的使得符合某個條件的元素放在前面


2. 比較函數:

當你需要按照某種特定方式進行排序時,你需要給sort指定比較函數,否則程序會自動提供給你一個比較函數

vector < int > vect;

sort(vect.begin(), vect.end());//此時相當于調用

sort(vect.begin(), vect.end(), less<int>() );

sort 中的其他比較函數

equal_to 相等

not_equal_to 不相等

less 小于

greater 大于

less_equal 小于等于

greater_equal 大于等于

上述例子中系統 自己為sort提供了less仿函數。在STL中還提供了其他仿函 數,以下是仿函數列表: 不能直接寫入仿 函數的名字,而是要寫其重載的()函數: less<int>();

當你的容器中元 素時一些標準類型(int float char)或者string時,你可以直 接使用這些函數模板。但如果你時自己定義的類型或者你需要按照其他方式排序,你可以有兩種方法來達到效果:一種是自己寫比較函數。另一種是重載類型的'<'操作賦。

3. 全排序:

全排序即把所給定范圍所有的元素按照大小關系順序排列。sort采用的是成熟的"快速排序算法"(目前大部分STL版本已經不是采用簡單的快速排序,而是結合內插排序算法)。復雜度為n*log(n)。stable_sort采用的是"歸并排序",分派足夠內存時,其算法復雜度為n*log(n), 否則 其復雜度為n*log(n)*log(n),其優點是會保持相等元素之間的相對位置在排序前后保持一致。

用于全排序的函 數有:

1.void sort(RandomAccessIterator first, RandomAccessIterator last);

2.void sort(RandomAccessIterator first, RandomAccessIterator last,StrictWeakOrdering comp);

3.void stable_sort(RandomAccessIterator first, RandomAccessIterator last);

4.void stable_sort(RandomAccessIterator first, RandomAccessIterator last, StrictWeakOrdering comp);

4. 局部排序:

partial_sort采用的堆排序(heapsort),它在任何情況下的復雜度都是n*log(n)。

局部排序其實是為了減少不必要的操作而提供的排序方式。

其函數原型為:

4.1 void partial_sort(RandomAccessIterator first, RandomAccessIterator middle,RandomAccessIterator last);

4.2 void partial_sort(RandomAccessIterator first,RandomAccessIterator middle,RandomAccessIterator last, StrictWeakOrdering comp);

4.3 RandomAccessIterator partial_sort_copy(InputIterator first, InputIteratorlast,RandomAccessIteratorresult_first,RandomAccessIterator result_last);

4.4 RandomAccessIterator partial_sort_copy(InputIterator first, InputIteratorlast,RandomAccessIteratorresult_first,RandomAccessIterator result_last, Compare comp);

例如:班上有1000個學生,我想知道分數最低的5名是哪些人。

partial_sort(vect.begin(),vect.begin()+5,vect.end(),less<student>());

5. nth_element 指定元素排序

5.1 void nth_element(RandomAccessIterator first, RandomAccessIterator nth, RandomAccessIterator last);

5.2 void nth_element(RandomAccessIterator first, RandomAccessIterator nth,RandomAccessIterator last,

StrictWeakOrdering comp);

例如:班上有1000個學生,我想知道分數排在倒數第4名的學生。

nth_element(vect.begin(), vect.begin()+3, vect.end(),less<student>());

6. partition 和stable_partition

partition就是把一個區間中的元素按照某個條件分成兩類,并沒有排序。

其函數原型為:

6.1 ForwardIterator partition(ForwardIterator first, ForwardIterator last, Predicate pred)

6.2 ForwardIterator stable_partition(ForwardIterator first, ForwardIterator last, Predicate pred);

例如:班上10個學生,計算所有沒有及格(低于60分)的學生:

student exam("pass", 60);

stable_partition(vect.begin(), vect.end(), bind2nd(less<student>(), exam));

7. 效率由高到低(耗時由小變大):

partion

stable_partition

nth_element

partial_sort

sort

stable_sort

8. Effective STL對如何選擇排序函數總結的很好:

8.1 若需對vector, string, deque, 或array容器進行全排序,你可選擇sort或stable_sort;

8.2 若只需對vector, string, deque, 或array容器中取得top n的元素,部分排序partial_sort是首選.

8.3 若對于vector, string, deque, 或array容器,你需要找到第n個位置的元素或者你需要得到top n且不關系top n中的內部 順序,nth_element是最 理想的;

8.4 若你需要從標準序列容器或者array中把滿足某個條件 或者不滿足某個條件的元素分開,你最好使用partition或stable_partition;

8.5 若使用的list容器,你可以直接使用partition和stable_partition算法,你可以使用list::sort代替sort和stable_sort排 序。

上述的資料就是武林技術頻道小編介紹的STl中的排序算法詳細解析,做什么都要用于去嘗試,面對互聯網帶來的便利我們要利用好它。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97av在线视频| 国产一区二区日韩精品欧美精品| 国产精品一久久香蕉国产线看观看| 色噜噜狠狠狠综合曰曰曰| 亚洲精品永久免费精品| 亚州欧美日韩中文视频| 成人信息集中地欧美| 91精品国产综合久久男男| 日韩在线观看免费全| 91精品久久久久久久久久另类| 欧美xxxx18性欧美| 亚洲最大成人网色| 亚洲bt欧美bt日本bt| 欧美中在线观看| 亚洲欧美日韩综合| 日韩av手机在线看| 在线日韩精品视频| 欧美成人午夜激情视频| 最新国产成人av网站网址麻豆| 91夜夜未满十八勿入爽爽影院| 日韩在线观看成人| 欧美日韩精品在线播放| 17婷婷久久www| 国产狼人综合免费视频| 亚洲国产精品成人精品| 欧美激情欧美激情| 日韩免费在线电影| 日韩欧美亚洲国产一区| 国内精品久久影院| 久久综合久中文字幕青草| 久久躁狠狠躁夜夜爽| 久久久电影免费观看完整版| 久久99青青精品免费观看| 亚洲第一区中文99精品| 欧美一级在线亚洲天堂| 日韩欧美极品在线观看| 精品国产欧美一区二区五十路| 91探花福利精品国产自产在线| 国产精品福利网| 亚洲精品国产品国语在线| 国产精品老牛影院在线观看| 国产女人18毛片水18精品| 日韩电视剧在线观看免费网站| 高清欧美电影在线| 久久久伊人欧美| 97久久久免费福利网址| 91精品中国老女人| 一区二区三区久久精品| 久久久999成人| 国产精品美乳在线观看| 欧美大片欧美激情性色a∨久久| 亚洲综合色激情五月| 深夜福利亚洲导航| 国产精品www色诱视频| 91性高湖久久久久久久久_久久99| 亚洲区一区二区| 欧美激情视频播放| 欧美尺度大的性做爰视频| 亚洲的天堂在线中文字幕| www国产91| 欧美激情啊啊啊| 亚洲欧美日韩另类| 亚洲xxx视频| 亚洲色图18p| 亚洲视频在线免费观看| 国产精品视频不卡| 久久成人精品视频| 91精品在线一区| 不用播放器成人网| 中文字幕亚洲一区| 久久国产精品免费视频| 亚洲成人精品av| 欧洲午夜精品久久久| 91在线视频一区| 亚洲国产精久久久久久久| 97在线观看免费高清| 欧美电影第一页| 亚洲精品国产精品国自产观看浪潮| 欧美色视频日本版| 日韩av在线免费看| 日韩欧美亚洲范冰冰与中字| 国产精品久久中文| 国产精品你懂得| 日韩美女免费线视频| 亚洲男人第一av网站| 国产不卡av在线| 成人黄色免费网站在线观看| 国产一区二区视频在线观看| 精品亚洲一区二区三区| 国内精品一区二区三区四区| 色系列之999| 精品美女永久免费视频| 国产精品第3页| 8050国产精品久久久久久| 性欧美xxxx交| 欧美肥臀大乳一区二区免费视频| 久久精品2019中文字幕| 成人免费xxxxx在线观看| 精品成人69xx.xyz| 成人有码在线视频| 国产98色在线| 91精品国产91久久久久福利| 精品久久久91| 久久久国产精彩视频美女艺术照福利| 国产日韩在线一区| 久久久亚洲国产天美传媒修理工| 黄色成人av在线| 国产91精品久久久久久| 亚洲国产高清福利视频| 成人黄色中文字幕| 91精品国产91久久久久久| 久久久国产精彩视频美女艺术照福利| 欧美日韩色婷婷| 中文字幕久热精品视频在线| 136fldh精品导航福利| 欧美成人精品一区| 亚洲精品suv精品一区二区| 国产精品一区二区久久国产| 久久精品国产v日韩v亚洲| 色小说视频一区| 日韩av综合网| 国产一区二区三区中文| 亚洲自拍小视频免费观看| 日韩性生活视频| 亚洲码在线观看| 亚洲第一级黄色片| 日韩精品视频在线播放| 国产精品99久久久久久白浆小说| 日韩欧美亚洲成人| 在线精品播放av| 精品国产区一区二区三区在线观看| 国产不卡在线观看| 正在播放欧美一区| 久久影院免费观看| 日韩精品中文字幕视频在线| 人妖精品videosex性欧美| 国产精品美女999| 亚洲四色影视在线观看| 中文字幕日韩精品在线| 欧美香蕉大胸在线视频观看| 大荫蒂欧美视频另类xxxx| 午夜精品在线观看| 精品久久久久久中文字幕一区奶水| 亚洲欧洲在线免费| 亚洲国产精品va| 欧洲成人免费aa| 丝袜美腿亚洲一区二区| 成人激情视频小说免费下载| 欧美日韩一区二区三区在线免费观看| 亚洲国产精品va在线看黑人| 两个人的视频www国产精品| 欧美成人精品一区二区三区| 中文字幕日韩av综合精品| 精品亚洲国产成av人片传媒| 97国产一区二区精品久久呦| 欧美精品久久久久| 亚洲精品中文字幕有码专区| 亚洲人成在线观看网站高清| 日韩在线观看你懂的| 91国产一区在线| 精品国产91久久久久久| 成人性生交大片免费观看嘿嘿视频| 精品在线小视频| 欧美视频在线观看免费网址|