100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > C++中 结构体vector使用sort排序

C++中 结构体vector使用sort排序

时间:2020-07-15 10:11:48

相关推荐

C++中 结构体vector使用sort排序

一、遇到问题:

今天写代码的是遇到想对vector进行排序的问题,隐约记得std::sort函数是可以对vector进行排序的,但是这次需要排序的vector中压的是自己定义的结构体(元素大于等于2),想以其中某一个元素进行正序或逆序排序,则不能直接使用sort函数。

二、解决方案:

1.C++中当 vector 中的数据类型为基本类型时,我们调用std::sort函数很容易实现 vector中数据成员的升序和降序排序,代码如下(摘自/reference/algorithm/sort/):

// sort algorithm example#include <iostream>// std::cout#include <algorithm> // std::sort#include <vector> // std::vectorbool myfunction (int i,int j) { return (i<j); }struct myclass {bool operator() (int i,int j) { return (i<j);}} myobject;int main () {int myints[] = {32,71,12,45,26,80,53,33};std::vector<int> myvector (myints, myints+8);// 32 71 12 45 26 80 53 33// using default comparison (operator <):std::sort (myvector.begin(), myvector.begin()+4); //(12 32 45 71)26 80 53 33// using function as compstd::sort (myvector.begin()+4, myvector.end(), myfunction); // 12 32 45 71(26 33 53 80)// using object as compstd::sort (myvector.begin(), myvector.end(), myobject);//(12 26 32 33 45 53 71 80)// print out content:std::cout << "myvector contains:";for (std::vector<int>::iterator it=myvector.begin(); it!=myvector.end(); ++it)std::cout << ' ' << *it;std::cout << '\n';return 0;}

输出为:

myvector contains: 12 26 32 33 45 53 71 80

2.然而当vector中的数据类型为自定义结构体类型时,我们该怎样实现排序?

其实就是对上面代码中std::sort函数的第三个参数comp调用的函数或object进行修改即可。在这里我们使用函数作为comp作为例子,代码如下:

#include <vector>#include <iostream>#include <algorithm>using namespace std;struct Point2{int x;int y;};bool GreaterSort (Point2 a,Point2 b) { return (a.x>b.x); }bool LessSort (Point2 a,Point2 b) { return (a.x<b.x); }int main(){vector<Point2> aaa;Point2 temp;temp.x=1;temp.y=1;aaa.push_back(temp);temp.x=2;temp.y=2;aaa.push_back(temp);temp.x=3;temp.y=3;aaa.push_back(temp);sort(aaa.begin(),aaa.end(),GreaterSort);//降序排列cout<<"Greater Sort:"<<endl;for (int i =0;i<aaa.size();i++){cout<<aaa[i].x<<""<<aaa[i].y<<endl;}sort(aaa.begin(),aaa.end(),LessSort);//升序排列cout<<"Less Sort:"<<endl;for (int i =0;i<aaa.size();i++){cout<<aaa[i].x<<""<<aaa[i].y<<endl;}return 1;}

运行结果如下:

Greater Sort:3 32 21 1Less Sort:1 12 23 3

以上代码在visual stdio 环境下编译通过,也是自己在实践过程中的总结,如有不妥的地方,欢迎您指出。

三、参考文献:

/reference/algorithm/sort/

/aguisy/article/details/5787257

(转载请注明作者和出处:/zhouxun未经允许请勿用于商业用途)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。