我是靠谱客的博主 暴躁仙人掌,最近开发中收集的这篇文章主要介绍数据结构与算法——找出数组中唯一的重复元素,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

如何找出数组中唯一的重复元素

数组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;
}

最后

以上就是暴躁仙人掌为你收集整理的数据结构与算法——找出数组中唯一的重复元素的全部内容,希望文章能够帮你解决数据结构与算法——找出数组中唯一的重复元素所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(59)

评论列表共有 0 条评论

立即
投稿
返回
顶部