简谈俩种不同方式对vector容器的 自定义结构体进行排序

俩种方法,自己容易忘所以记下来了

一:重载< 比较运算符,最后可以直接用sort()排序

     比如:

bool operator < (const Time r)const { return  hh * 3600 + mm * 60 + ss < r.hh * 3600 + r.mm * 60 + r.ss; }


二:自定义比较函数cmp,最后可以sort(a.begin(),a.end(),cmp)来实现    

    比如:

bool cmp(const Time &a,const Time &b)
{
	return a.hh * 3600 + a.mm * 60 + a.ss > b.hh * 3600 + b.mm * 60 + b.ss;
}
示例程序:

#include<iostream>
#include<string>
#include<vector>
#include<cmath>
#include<algorithm>
struct Time
{
	int hh, mm, ss;
	Time(){}
	Time(int _hh, int _mm, int _ss) :hh(_hh), mm(_mm), ss(_ss){}
	//重载< 这个运算符
	bool operator < (const Time r)const { return  hh * 3600 + mm * 60 + ss < r.hh * 3600 + r.mm * 60 + r.ss; }

};
//定义一个比较大小的函数
bool cmp(const Time &a,const Time &b)
{
	return a.hh * 3600 + a.mm * 60 + a.ss > b.hh * 3600 + b.mm * 60 + b.ss;
}
using namespace std;
int m, n;
int main()
{
	//cin >> m >> n;
	vector<Time> a;
	a.push_back(Time(05, 06, 07));
	a.push_back(Time(15, 04, 07));
	a.push_back(Time(05, 06, 04));
	a.push_back(Time(14, 06, 07));
	a.push_back(Time(06, 07, 18));
	//用cmp函数 从大到小排
	sort(a.begin(), a.end(),cmp);
	for (int i = 0; i < a.size(); i++)
	{
		cout << "hh: "<<a[i].hh<<" mm: "<<a[i].mm<<" ss: "<<a[i].ss<< endl;
	}
	cout << endl;
	//通过重载< 符号,从小到大排
	sort(a.begin(), a.end());
	for (int i = 0; i < a.size(); i++)
	{
		cout << "hh: " << a[i].hh << " mm: " << a[i].mm << " ss: " << a[i].ss << endl;
	}
	return 0;
}

结果图如下:



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值