一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - STl中的排序算法詳細解析

STl中的排序算法詳細解析

2021-01-01 13:03C語言教程網(wǎng) C/C++

全排序即把所給定范圍所有的元素按照大小關系順序排列。sort采用的是成熟的"快速排序算法"(目前大部分STL版本已經(jīng)不是采用簡單的快速排序,而是結合內(nèi)插排序算法)

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

函數(shù)名             功能描述

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

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

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

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

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

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

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

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


2. 比較函數(shù):

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

vector < int > vect;

sort(vect.begin(), vect.end());//此時相當于調(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>();

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

3. 全排序:

全排序即把所給定范圍所有的元素按照大小關系順序排列。sort采用的是成熟的"快速排序算法"(目前大部分STL版本已經(jīng)不是采用簡單的快速排序,而是結合內(nèi)插排序算法)。復雜度為n*log(n)。stable_sort采用的是"歸并排序",分派足夠內(nèi)存時,其算法復雜度為n*log(n), 否則 其復雜度為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),它在任何情況下的復雜度都是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個學生,我想知道分數(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個學生,我想知道分數(shù)排在倒數(shù)第4名的學生。

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個學生,計算所有沒有及格(低于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對如何選擇排序函數(shù)總結的很好:

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中的內(nèi)部 順序,nth_element是最 理想的;

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

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

延伸 · 閱讀

精彩推薦
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++C語言實現(xiàn)電腦關機程序

    C語言實現(xiàn)電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++c++ 單線程實現(xiàn)同時監(jiān)聽多個端口

    c++ 單線程實現(xiàn)同時監(jiān)聽多個端口

    這篇文章主要介紹了c++ 單線程實現(xiàn)同時監(jiān)聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C/C++經(jīng)典實例之模擬計算器示例代碼

    C/C++經(jīng)典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經(jīng)典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數(shù)使用

    詳解c語言中的 strcpy和strncpy字符串函數(shù)使用

    strcpy 和strcnpy函數(shù)是字符串復制函數(shù)。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數(shù)使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++深入理解goto語句的替代實現(xiàn)方式分析

    深入理解goto語句的替代實現(xiàn)方式分析

    本篇文章是對goto語句的替代實現(xiàn)方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網(wǎng)7342020-12-03
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內(nèi)存中的數(shù)據(jù)都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數(shù)據(jù),C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
主站蜘蛛池模板: 色噜噜国产精品视频一区二区 | 放荡警察巨r麻麻出轨小说 范冰冰特黄xx大片 饭冈加奈子在线播放观看 法国老妇性xx在线播放 | bnb998八度免费影院丫意浓 | 成人无高清96免费 | 亚洲欧美精品一区天堂久久 | 亚洲人成在线观看一区二区 | yellow高清免费观看日本 | 免费一级毛片在线播放放视频 | 关晓彤被调教出奶水 | 深夜网站在线观看 | 第一次破女视频国产一级 | 精品国产线拍大陆久久尤物 | japanese日本护士 | 国产caoni555在线观看 | 精品欧美一区二区精品久久 | xx18-19xxxxhd| 成年人免费观看视频网站 | 日本漫画无翼乌 | 潘甜甜在线观看 | 欧美美女被爆操 | 亚洲图片二区 | 美女视频在线观看视频 | 亚洲六月丁香婷婷综合 | 欧美国产日本精品一区二区三区 | 日本中文字幕一区二区高清在线 | 免费看美女被靠到爽 | 国产香蕉一区二区在线观看 | 亚洲国产精品第一区二区三区 | 国产灌醉 | 特级老女人淫片高清视频 | 国产精品www视频免费看 | 99热精品在线播放 | 成年人免费在线看的惊悚动作片 | 欧美久久一区二区三区 | 亚洲视频999 | ysl千人千色t9t9t9t9| 32pao强力打造免费高速高 | 国产区成人综合色在线 | 538免费精品视频搬运工 | 我的男友是消防员在线观看 | 亚洲欧美色综合图小说 |