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条)

报告相同问题?

悬赏问题

  • ¥15 PointNet++的onnx模型只能使用一次
  • ¥20 西南科技大学数字信号处理
  • ¥15 有两个非常“自以为是”烦人的问题急期待大家解决!
  • ¥30 STM32 INMP441无法读取数据
  • ¥15 R语言绘制密度图,一个密度曲线内fill不同颜色如何实现
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧,别用大模型回答,大模型的答案没啥用
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。