zhaoImpulse0 2011-05-10 18:51
浏览 246
已采纳

一个算法问题

说有一组数,N个,各不相同,然后把这个数组容易加倍,把里面的数都复制一次放进去,就是2N个
然后随机删除一个数,变成2N-1个,从这里找出那个删除的数(给你的就是2N-1个数,所以不能用2N数的和减2n-1个数的和)
请各位给点思路
方法一定要简单

  • 写回答

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥20 用51单片机控制急停。
  • ¥15 孟德尔随机化结果不一致
  • ¥15 在使用pyecharts时出现问题
  • ¥15 深度学习残差模块模型
  • ¥50 怎么判断同步时序逻辑电路和异步时序逻辑电路
  • ¥15 差动电流二次谐波的含量Matlab计算
  • ¥15 Can/caned 总线错误问题,错误显示控制器要发1,结果总线检测到0
  • ¥15 C#如何调用串口数据
  • ¥15 MATLAB与单片机串口通信
  • ¥15 L76k模块的GPS的使用