C++ STL中Map的按Key排序和按Value排序

17 篇文章 0 订阅

如何实现Map的按Value排序呢?

        第一反应是利用STL中提供的sort算法实现,这个想法是好的,不幸的是,sort算法有个限制,利用sort算法只能对序列容器进行排序,就是线性的(如vector,list,deque)。map是一个集合容器,它里面存储的元素是pair,但是它不是线性存储的(像红黑树),所以利用sort不能直接和map结合进行排序。因而可以采用一些其它的思路,代码如下:

HelloWorld::init()
{
	if (!Layer::init())
	{
		return false;
	}
	std::map<int, Test> _intMap;
	for (int i = 0; i < 10; i++)
	{
		Test test;
		test.setI(i * 8);
		_intMap.insert(std::make_pair(i, test));
	}
	vector<pair<int, Test>> tVector;
	sortMap(_intMap, tVector);
	for (auto iter = tVector.begin(); iter != tVector.end(); iter++)
	{
		log("first====%d,second===%d", iter->first, iter->second);
	}
	return true;
}
bool HelloWorld::sortVec(const pair<int, Test>& test1, const pair<int, Test>& test2)
{
	return test1.second.m_i > test2.second.m_i;
}

void HelloWorld::sortMap(map<int, Test>& tMap, vector<std::pair<int, Test>>& tVector)
{
	for (auto curr = tMap.begin(); curr != tMap.end(); curr++)
	{
		tVector.push_back(make_pair(curr->first, curr->second));
	}
	sort(tVector.begin(), tVector.end(),HelloWorld::sortVec);
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值