如何找出数组中唯一的重复元素
数组a[N],1~N-1这N-1个数存放在a[N]中,其中只有唯一的一个数重复了,写一个函数,找出这个重复的数字。要求每个数组元素只能访问一次,不用辅助存储空间
方法一:求和法
因为只有一个数字重复一次,而数又是连续的,根据累加和原理,对数组的所有项求和,然后减去1~N-1的和,即为所求的重复数
int findDup(vector<int> &a, int N)
{
int temp1 = 0;
int temp2 = 0;
for (int i = 0; i < N-1; ++i)
{
temp1 += (i + 1);
temp2 += a[i];
}
temp2 += a[N-1];
int result = temp2 - temp1;
return result;
}
方法二:异或法
根据异或法的计算方式,每两个相同的数执行异或运算之后,结果为0,所以数组a[N]中的N个数异或结果与1~N-1异或的结果再做异或,得到的值即为所求
int xor_findDup(vector<int> &a, int N)
{
int result = 0;
for (int i = 0; i < N; i++)
{
result ^= a[i];
}
for (int i = 1; i < N; i++)
{
result ^= i;
}
result result;
}
最后
以上就是暴躁仙人掌最近收集整理的关于数据结构与算法——找出数组中唯一的重复元素的全部内容,更多相关数据结构与算法——找出数组中唯一内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复