代码如下:
#include <iostream>
using namespace std;
void work(int a[], int n)
{
int i = 0;
while(i < n)
{
int temp = a[i] - 1;
if(temp < 0)
{
i++;
continue;
}
if(a[temp] > 0)
{
a[i] = a[temp];
a[temp] = -1;
}
else
{
a[temp]--;
a[i] = 0;
}
}
}
int main()
{
int n = 10;
int *a = new int[n];
for(int i = 0; i < n; i++)
cin >> a[i];
work(a, n);
for(int i = 0; i < n; i++)
if(a[i] < 0)
cout << i + 1 << " " << (-a[i]) << endl;
cout << "********************" << endl;
delete[] a;
return 0;
}
本文介绍了一个使用C++实现的数组操作算法,该算法通过重新排列数组中的元素并标记重复出现的数字,最终输出所有重复数字及其出现次数。此算法采用了一个独特的策略来确保每个数字仅被标记一次。
1130

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



