mapmap

https://www.luogu.com.cn/problem/P1097

统计数字出现个数,当数字特别大时

#include<bits/stdc++.h>
using namespace std;
int main()
{
	map<long long,int> m;
	int n;
	cin>>n;
	long long s;
	for(int i=1;i<=n;i++)
	{
		cin>>s;
		m[s]++;
	}
	for(map<long long,int>::iterator it=m.begin();it!=m.end();it++)
	{
		cout<<(*it).first<<" "<<(*it).second<<endl;
	}
}

https://www.luogu.com.cn/problem/P1102
给出一个数组,给出C。
在数组中选出A和B数对,使得A-B=C,问有多少对

#include<bits/stdc++.h>
#define ll long long
using namespace std;
int main()
{
	map<ll,ll> m;
	ll n,c;
	cin>>n>>c;
	ll a[200005];
	for(int i=1;i<=n;i++)
	{
		cin>>a[i];
		m[a[i]]++; //map中记录每个数出现的次数
		a[i]-=c; //A-B=C,可以转换为A-C=B,此处执行A-C,此时a[i]含义是 当A取第i个数时B的值 
	}	
	ll ans=0;
	for(int i=1;i<=n;i++)
		ans+=m[a[i]]; //从第一个数开始遍历A,然后看有多少个适合的B
	cout<<ans<<endl; 
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

henulmh

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值