pat乙级1083
#include <iostream>
#include <algorithm>
#include <map>
using namespace std;
int main()
{
int n,cha[10005];
cin >> n;
map<int, int> mp;
for (int i = 0; i < n; i++)
cin >> cha[i];
for (int i = 0; i < n; i++)
{
cha[i] = abs(cha[i] - i - 1);
mp[cha[i]]++;
}
for (auto it=mp.rbegin();it!=mp.rend();it++)
{
if(it->second != 1)
cout << it->first << " " << it->second << endl;
}
return 0;
}
本文提供了一段解决PAT乙级1083题目的C++代码实现,通过使用map数据结构来统计元素的绝对差值,从而找出重复次数超过一次的元素。
886

被折叠的 条评论
为什么被折叠?



