说有一组数,N个,各不相同,然后把这个数组容易加倍,把里面的数都复制一次放进去,就是2N个
然后随机删除一个数,变成2N-1个,从这里找出那个删除的数(给你的就是2N-1个数,所以不能用2N数的和减2n-1个数的和)
请各位给点思路
方法一定要简单
一个算法问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
6条回答 默认 最新
- iteye_14679 2011-05-11 14:51关注
这个就是简单的找出一个出现奇数次的数
全部异或一次就可以了比如
原数组= {1 3 2 2}
复制后= {1 3 2 2 1 3 2 2}
不管删除哪一个,其余的数都出现偶数字,只有那个被删除的数出现奇数次
由于a^a=0 0^a=a
那么全部异或一次后得到的结果就是被删除的那个数
比如删除最后一个2
那么
1^3^2^2^1^3^2=2本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报