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 排序(降序、升序)使用总结的文章就介绍到这了,更多相关C++降序、升序内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
我想按第三个和第一个元素对元组数组进行排序,因此我使用了以下代码: 我的问题是,在前面的例子中,我可以按第三个元素和第一个元素的升序排序,也可以按它们的降序排序(使用反向)。但是如何按第三个元素的升序和第一个元素的降序排序。 请在你的回答中考虑以下情况: 在这种情况下,我不知道内部数组的确切大小(取决于我读入该数组的文件模式),我想按侧中的所有项进行排序(一些升序和一些降序)。 编辑:看起来,我明
有人能提供帮助,如何检查排序降序数组以及?干杯!
问题内容: 我有一个带有产品的mysql表。 这些产品具有类别ID和名称。 我想做的是按类别ID顺序降序排列,然后按产品名称升序排列。 我想要的是 不幸的是,这是行不通的。 甚至可以在mysql中定义第二个排序列的排序顺序吗? 问题答案: 您可以通过以下方式进行操作: 看看优化
我有一个通用的链表,目前由int组成,我想在默认情况下按升序排序,然后切换一个布尔值,按降序排序。我该怎么做?
问题内容: 我想对seq1升序和seq2降序排序,所以我这样做: 但是结果出来了,因为seq1和seq2都按降序排序。 我可以这样做以使seq1升序和seq2降序: 真正正确的方法是什么? 问题答案: 在第一个示例中,将其应用于整个比较器,该比较器按升序比较seq1和seq2。 您需要的是仅反转第二个比较,例如,可以使用以下方法完成:
我正在尝试对我的数组进行升序和降序排序。不过,我似乎不知道如何正确地执行此操作。我尝试了不同的方法,但都不起作用。当我单击两个按钮时,应该会发生这种情况,一个ID为“stigande”升序,一个ID为“ 爪哇语