麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > C > 正文

STl中的排序算法詳細解析

2020-02-24 14:25:06
字體:
供稿:網(wǎng)友

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

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

函數(shù)名???          功能描述

sort        ? 對給定區(qū)間所有元素進行排序

stable_sort     對給定區(qū)間所有元素進行穩(wěn)定排序

partial_sort     對給定區(qū)間所有元素部分排序

partial_sort_copy??? 對給定區(qū)間復(fù)制并排序

nth_element     找出給定區(qū)間的某個位置對應(yīng)的元素

is_sorted?????????????? 判斷一個區(qū)間是否已經(jīng)排好序

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

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


2. 比較函數(shù):

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

vector < int > vect;

sort(vect.begin(), vect.end());//此時相當(dāng)于調(diào)用

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

sort 中的其他比較函數(shù)

equal_to 相等

not_equal_to 不相等

less 小于

greater 大于

less_equal 小于等于

greater_equal 大于等于

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

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

3. 全排序:

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

用于全排序的函 數(shù)有:

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),它在任何情況下的復(fù)雜度都是n*log(n)。

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

其函數(shù)原型為:

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個學(xué)生,我想知道分數(shù)最低的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個學(xué)生,我想知道分數(shù)排在倒數(shù)第4名的學(xué)生。

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

6. partition 和stable_partition

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

其函數(shù)原型為:

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

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

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

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對如何選擇排序函數(shù)總結(jié)的很好:

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且不關(guān)系top n中的內(nèi)部 順序,nth_element是最 理想的;

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

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

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

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

圖片精選

主站蜘蛛池模板: av黄色在线免费观看 | 亚洲一级电影在线观看 | 成人 日韩| 九九精品在线播放 | 久久免费视频3 | 欧美在线一级 | 久久久中文 | 日日操夜夜操视频 | 欧美黄色视屏 | 日产精品一区二区三区在线观看 | 黑人日比 | 羞羞羞网站| 中文字幕在线观看精品 | 亚洲天堂ww| 在线成人免费观看www | 91成人在线免费视频 | 国产91大片 | 怦然心动50免费完整版 | 精精国产xxxx视频在线野外 | 日本在线视频二区 | 日本中文字幕网址 | av免费在线播放网址 | 性爱在线免费视频 | 97久久人人超碰caoprom | 欧美成人精品h版在线观看 久久久久久三区 | 国产91亚洲精品一区二区三区 | 澳门一级淫片免费视频 | 国产精品99精品 | 福利一区二区三区视频在线观看 | 国产91丝袜在线播放0 | 成人在线免费观看小视频 | 亚洲成人高清电影 | 日日草视频| 黄色片网站免费观看 | 成人爱爱电影 | 曰韩av在线| 国产精品久久久免费观看 | 色女人在线 | 欧美一级黄色免费看 | 特级无码毛片免费视频尤物 | 一级α片免费看 |