本篇文章給大家分享的是有關如何在C++中利用 sort函數實現升序或降序,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
C++ sort 函數十分方便,可以對內置類型也可對自定義類型進行快速排序,內置類型的使用比較簡單,下面主要討論自定義類型的排序,一般有如下幾種使用方法:
比如,我們現有一批學生,要根據他們的成績進行升序排序,成績如果相等則根據名字升序排序,那么我們可以如下操作:
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;
}運行結果如下圖:

當然,我們也可以自己寫比較函數,實現如下:
bool cmp(const Student& lhs, const Student& rhs){
return lhs.grade < rhs.grade
|| (lhs.grade == rhs.grade && lhs.name < rhs.name);
}按如下方式調用:
sort(begin(vec),end(vec), cmp);
另外一種方式,即構造一個函數對象,抑或叫 functor,其實就是實現了重載 operator() 的一個類,代碼如下:
struct Compare{
bool operator()(const Student& lhs, const Student& rhs){
return lhs.grade < rhs.grade
|| (lhs.grade == rhs.grade && lhs.name < rhs.name);
}
};按如下方式調用:
sort(begin(vec),end(vec), Compare());
C++11有了 Lambda 之后,就不必再為某些小函數寫具名函數了,如下使用即可:
sort(begin(vec), end(vec), [](const Student& lhs, const Student& rhs) {
return lhs.grade < rhs.grade
|| (lhs.grade == rhs.grade && lhs.name < rhs.name); });降序排序的方法與升序類似,如果采用比較函數、Lambda 或者比較函數的方式,只需要改一改比較條件就OK了,但是,如果對于Student類,我們定義了 operator < 之后,不想為了降序排序再定義一個 operator > 怎么辦?兩種辦法!
升序排序之后,用 reverse 反轉即可。
直接按如下方式調用即可,不用再去重載 operator >
sort(vec.rbegin(), vec.rend());
對一個5位數的任意整數,求出其降序數。例如,整數是82319,則其降序數是98321。算法提示:將整數的各位數分解到一維整型數組a中,再將a數組中的元素按降序排序,最后輸出a數組元素值。
試建立一個類DescendNUM,用于完成該功能。具體要求如下:
(1)私有數據成員
int n:存放5位數的整數。
int a[5]:存放其元素的降序排列值。
(2)公有成員函數
DescendNUM(int x=0):構造函數,用參數x初始化n。
void decompose ():將n的各位數分解到a數組。
void dsort():將a數組排成降序。
void show():顯示元素及其降序數。
(3)在主函數中輸入一個5位數的任意整數,然后定義一個DescendNUM類對象num,用上述輸入的數初始化num,然后完成對該類的測試。
#include "stdafx.h"
#include<iostream>
using namespace std;
class DescendNUM
{
public:
DescendNUM(int x){ n = x;}//:構造函數,用參數x初始化n。
void decompose ();//:將n的各位數分解到a數組。
void dsort();//:將a數組排成降序。
void show();//:顯示元素及其降序數。
private:
int n;//:存放5位數的整數。
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;
}以上就是如何在C++中利用 sort函數實現升序或降序,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。