C++基础之map按key排序

在项目当中有要用到map按key排序的需求,就在百度上搜了一下:

typedef pair<int,int> PAIR;

int cmp(const PAIR& x, const PAIR& y)
{
return x.second < y.second;
}



map<int,int> imgdis; //待排序对象,根据double值排序
imgdis[1] = 3;
imgdis[10] = 1;
imgdis[3] = 5;
imgdis[12] = 4;
imgdis[5] = 4;
vector<PAIR> vecpair;

for (map<int,int>::iterator curr = imgdis.begin(); curr != imgdis.end(); ++curr) 
{ 
vecpair.push_back(make_pair(curr->first, curr->second)); 
}
sort(vecpair.begin(), vecpair.end(), cmp);

//输出排序后的键值对
for(int i = 0 ;i<vecpair.size();i++) 
{
cout<<" "<<vecpair[i].first<<" "<<vecpair[i].second<<endl;
}

有更好的方法,欢迎推荐啊

转载于:https://www.cnblogs.com/aj007/p/4211913.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值