C++ sort排序之降序、升序使用總結(jié)
一、升序
C++ sort 函數(shù)十分方便,可以對(duì)內(nèi)置類(lèi)型也可對(duì)自定義類(lèi)型進(jìn)行快速排序,內(nèi)置類(lèi)型的使用比較簡(jiǎn)單,下面主要討論自定義類(lèi)型的排序,一般有如下幾種使用方法:
1.1 重載比較操作符
比如,我們現(xiàn)有一批學(xué)生,要根據(jù)他們的成績(jī)進(jìn)行升序排序,成績(jī)?nèi)绻嗟葎t根據(jù)名字升序排序,那么我們可以如下操作:
struct Student{
string name;
int grade;
Student(string name, int grade) : name(name), grade(grade){}
bool operator < (const Student& rhs) const{
return grade < rhs.grade
|| (grade == rhs.grade && name < rhs.name);
}
friend void operator << (ostream& output, const Student& s){
output << s.name << " " << s.grade << endl;
}
};
int main()
{
vector<Student> vec;
vec.emplace_back("Jack", 20);
vec.emplace_back("John", 30);
vec.emplace_back("Amy", 20);
vec.emplace_back("Bill", 90);
cout << "Before:" << endl;
for(auto& s : vec){
cout << s;
}
sort(begin(vec),end(vec));
cout << endl << "After:" << endl;
for(auto& s : vec){
cout << s;
}
return 0;
}
運(yùn)行結(jié)果如下圖:

1.2 比較函數(shù)
當(dāng)然,我們也可以自己寫(xiě)比較函數(shù),實(shí)現(xiàn)如下:
bool cmp(const Student& lhs, const Student& rhs){
return lhs.grade < rhs.grade
|| (lhs.grade == rhs.grade && lhs.name < rhs.name);
}
按如下方式調(diào)用:
sort(begin(vec),end(vec), cmp);
1.3 函數(shù)對(duì)象
另外一種方式,即構(gòu)造一個(gè)函數(shù)對(duì)象,抑或叫 functor,其實(shí)就是實(shí)現(xiàn)了重載 operator() 的一個(gè)類(lèi),代碼如下:
struct Compare{
bool operator()(const Student& lhs, const Student& rhs){
return lhs.grade < rhs.grade
|| (lhs.grade == rhs.grade && lhs.name < rhs.name);
}
};
按如下方式調(diào)用:
sort(begin(vec),end(vec), Compare());
1.4 Lambda
C++11有了 Lambda 之后,就不必再為某些小函數(shù)寫(xiě)具名函數(shù)了,如下使用即可:
sort(begin(vec), end(vec), [](const Student& lhs, const Student& rhs) {
return lhs.grade < rhs.grade
|| (lhs.grade == rhs.grade && lhs.name < rhs.name); });
二、降序
降序排序的方法與升序類(lèi)似,如果采用比較函數(shù)、Lambda 或者比較函數(shù)的方式,只需要改一改比較條件就OK了,但是,如果對(duì)于Student類(lèi),我們定義了 operator < 之后,不想為了降序排序再定義一個(gè) operator > 怎么辦??jī)煞N辦法!
2.1 reverse
升序排序之后,用 reverse 反轉(zhuǎn)即可。
2.2 反向迭代
直接按如下方式調(diào)用即可,不用再去重載 operator >
sort(vec.rbegin(), vec.rend());
三、實(shí)例補(bǔ)充
對(duì)一個(gè)5位數(shù)的任意整數(shù),求出其降序數(shù)。例如,整數(shù)是82319,則其降序數(shù)是98321。算法提示:將整數(shù)的各位數(shù)分解到一維整型數(shù)組a中,再將a數(shù)組中的元素按降序排序,最后輸出a數(shù)組元素值。
試建立一個(gè)類(lèi)DescendNUM,用于完成該功能。具體要求如下:
(1)私有數(shù)據(jù)成員
int n:存放5位數(shù)的整數(shù)。
int a[5]:存放其元素的降序排列值。
(2)公有成員函數(shù)
DescendNUM(int x=0):構(gòu)造函數(shù),用參數(shù)x初始化n。
void decompose ():將n的各位數(shù)分解到a數(shù)組。
void dsort():將a數(shù)組排成降序。
void show():顯示元素及其降序數(shù)。
(3)在主函數(shù)中輸入一個(gè)5位數(shù)的任意整數(shù),然后定義一個(gè)DescendNUM類(lèi)對(duì)象num,用上述輸入的數(shù)初始化num,然后完成對(duì)該類(lèi)的測(cè)試。
#include "stdafx.h"
#include<iostream>
using namespace std;
class DescendNUM
{
public:
DescendNUM(int x){ n = x;}//:構(gòu)造函數(shù),用參數(shù)x初始化n。
void decompose ();//:將n的各位數(shù)分解到a數(shù)組。
void dsort();//:將a數(shù)組排成降序。
void show();//:顯示元素及其降序數(shù)。
private:
int n;//:存放5位數(shù)的整數(shù)。
int a[5];//:存放其元素的降序排列值。
};
void DescendNUM::decompose ()
{
int i=0;
while(n!=0)
{
a[i++] = n%10;
n = n/10;
}
}
void DescendNUM::dsort()
{
int j,i,t;
int num=a[0];
for(i=0;i<4;i++)
for(j=0;j<5;j++)
{
if(a[j+1]>a[j])
{
t=a[j+1];
a[j+1]=a[j];
a[j] = t;
}
}
}
void DescendNUM::show()
{
int i;
for(i=0;i<5;i++)
{
cout<<a[i];
}
cout<<endl;
}
int main()
{
DescendNUM num(82319);
num.decompose ();
num.dsort();
num.show();
return 0;
}
到此這篇關(guān)于C++ sort 排序(降序、升序)使用總結(jié)的文章就介紹到這了,更多相關(guān)C++降序、升序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言中settimeofday函數(shù)和gettimeofday函數(shù)的使用
這篇文章主要介紹了C語(yǔ)言中的settimeofday函數(shù)和gettimeofday函數(shù)的使用,注意settimeofday()函數(shù)只返回0和-1,需要的朋友可以參考下2015-08-08
C++實(shí)現(xiàn)簡(jiǎn)易圖書(shū)館管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)易圖書(shū)館管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
C語(yǔ)言中使用lex統(tǒng)計(jì)文本文件字符數(shù)
這篇文章主要介紹了C語(yǔ)言中使用lex統(tǒng)計(jì)文本文件字符數(shù),本文直接給出實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-04-04
C語(yǔ)言 用while循環(huán)求和的平均值操作
這篇文章主要介紹了C語(yǔ)言 用while循環(huán)求和的平均值操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12
基于C++實(shí)現(xiàn)的各種內(nèi)部排序算法匯總
這篇文章主要介紹了基于C++實(shí)現(xiàn)的各種內(nèi)部排序算法,非常經(jīng)典,需要的朋友可以參考下2014-08-08
深入探索C++中stack和queue的底層實(shí)現(xiàn)
這篇文章主要介紹了C++中的stack和dequeue的底層實(shí)現(xiàn),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09
C++消息隊(duì)列(定義,結(jié)構(gòu),如何創(chuàng)建,發(fā)送與接收)
這篇文章主要介紹了C++消息隊(duì)列(定義,結(jié)構(gòu),如何創(chuàng)建,發(fā)送與接收),消息隊(duì)列是一種先進(jìn)先出的隊(duì)列型數(shù)據(jù)結(jié)構(gòu),實(shí)際上是系統(tǒng)內(nèi)核中的一個(gè)內(nèi)部鏈表2022-08-08
C++項(xiàng)目實(shí)戰(zhàn)之makefile使用
這篇文章主要介紹了C++項(xiàng)目實(shí)戰(zhàn)之makefile使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05

