vector用sort算法排序

用sort对vector排序有两种方法
方法1:
#include <vector>//容器的头文件
#include <algorithm> //sort算法用到的头文件
using namespace std;

  struct Info
{
 int x;
 bool operator >(const Info& Pinfo) const;  //降序排列需要重载的操作符
 bool operator <(const Info& pinfo) const;  //升序排列需要重载的操作符
};
bool Info::operator >(const Info& pinfo) const
{
 return x>pinfo.x;
}
bool Info::operator<(const Info& pinfo) const
{
 return x
}
int main(int argc, char* argv[])
{    vector m_vecInfo;
     for (int i=0;i<10;i++)
     {
      Info pInfo;
      pInfo.x=i;
      m_vecInfo.push_back(pInfo);
     }
 sort(m_vecInfo.begin(),m_vecInfo.end(),greater());//降序排列
 sort(m_vecInfo.begin(),m_vecInfo.end(),less()); //升序排列
 return 0;
}
 
方法2:
#include <vector>//容器的头文件
#include <algorithm> //sort算法用到的头文件
using namespace std;
 
struct Info {int x;};
bool copare(const Info* pfirst,const Info* psecond) //如果该vector存入的是对象的话该函数参数须是
{                                                    // 对象的引用,而不该是指针
 return pfirst->x>=psecond->x;
}
int main(int argc, char* argv[])
{ vector m_vecInfo;
Info* pInfo;
for (int i=0;i<10;i++)
{
pInfo = new Info;
pInfo->x=i;
m_vecInfo.push_back(pInfo);
}
sort(m_vecInfo.begin(),m_vecInfo.end(),copare); //按照自己写的排序函数进行排序
return 0;
}
总结:这两个方法都可实现vector的排序,当vector存入的是对象时两种方法都行(只要把第二种方法的用于排序的分成员函数的参数列表写成对象的引用即可),但是当vector里是指针的时候只能用第二种方法进行排序。
应该还有别的方法,但是我没有测试过,因此只介绍这两种方法。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值