寻找出现一次的数

题目:You are given an array A that contains integers. Every integer occurs 3 times in A leaving one integer that appears only once. Fastest way to find that single integer.

分析:如果这里的数组A的规模比较小,在内存的可以容纳的范围之内,可以建立hash表,顺序扫描A中的每一个 数,统计每个数的出现次数,最后找出仅出现一次的数即可,时间复杂度为O(N),空间复杂度为O(N)。如果数组A的规模很大呢?难道是进行外排序,然后 通过merge的方式找到吗?有没有更好的额方式?

如果这里的数不是出现三次而是出现两次,我们可以使用异或的方式将所有的数进行异或,最后的结果自然是仅出现一次的数,空间复杂度将为O(1)。这里考虑将数表达成3进制,每一位的异或操作:

  • 1 xo 0 = 1
  • 1 x0 1 = 2
  • 1 xo 2 = 0
  • 2 xo 0 = 2
  • 2 xo 2 = 1
  • 0 xo 0 = 0

这样,相同的三个数的同一位的异或值一定为0,0与x的异或等于x。通过将所有的数表示成三进制,一起异或,最后的结果为仅出现一次的数,所用的空间复杂度为O(1)。

网络转载请注明:转载自程序员面试之家

并注明本文链接地址: 寻找出现一次的数

posted @ 2011-10-03 16:14  westfly  阅读(281)  评论(0编辑  收藏  举报