逆转向迭代器

ural 1100

1 2
16 3
11 2
20 3
3 5
26 4
7 1
22 4
变成

3 5
26 4
22 4
16 3
20 3
1 2
11 2
7 1
也就是b相同的话就按顺序输出,否者按照b大的在前面

用map和vector的话,里面的元素默认是按照从小到大排的,这时候就需要用到转逆向迭代器

元素在map中的存在方式
[5]((1,[1](7)),(2,[2](1,11))..........)

表示共可以分类成5组,(2,[2](1,11))第一个2表示元素a的值,第二个2表示与元素2对应的数有几个,那么1和11就是与2对应的元素的值了

具体的看代码:

#include <iostream>
#include <stdio.h>
#include <vector>
#include <map>

using namespace std;

 int main () {
	int n;
 	std::cin >> n;
	std::map<int, std::vector<int> > m;
   	for (int i = 0; i < n; i++)
	{  
		int a, b;
		std::cin >> a >> b;
		m [b].push_back (a);
	} 
	std::map<int, std::vector<int> >::reverse_iterator it = m.rbegin ();
	while (it != m.rend ())
	{
		int _cnt = it->second.size ();
		for (int i = 0; i < _cnt; i++)
			std::cout << it->second [i] << " " << it->first << std::endl;
		it++;
	}
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值