HDU - 5463(Clarke and minecraft)stl中map的解法

#include<iostream>
#include<queue>
#include<algorithm>
#include<string>
#include<vector>
#include<cmath>
#include<map>
#include<set>
#include<cstring> 
using namespace std;
map<int,int>s;
int main()
{
	int n,m,a,b,t;
	scanf("%d",&n);
	while(n--)
	{
		scanf("%d",&m);
		int ans=0;
		s.clear();
		for(int i=1;i<=m;i++)
		{
			cin>>a>>b;
			if(!s.count(a)) s[a]=0;
			s[a]+=b;
		}
		map<int,int>::iterator it;
		for(it=s.begin();it!=s.end();it++)
		{
			t=it->second;
			if(t%64) t=(t/64)+1;
			else t=t/64;
			ans+=t;
		}
		if(ans%36) printf("%d\n",(ans/36)+1);
		else printf("%d\n" ,ans/36); 
	}
	return 0;
 } 
发布了3 篇原创文章 · 获赞 0 · 访问量 71

猜你喜欢

转载自blog.csdn.net/qq_45773654/article/details/104168242