leecode第二天-使用异或找出数组中的非重复元素

Posted worthy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leecode第二天-使用异或找出数组中的非重复元素相关的知识,希望对你有一定的参考价值。

leecode题目描述如下:
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。

思路:
最开始想到的是使用排序,排序之后就很容易找到非重复元素了。
后面看到网上有更巧妙的解决办法,即使用异或来找出非重复元素,因为重复的元素经异或之后就互相抵消为0了,最后数组各个元素经过异或计算之后的结果就是那个唯一的非重复元素。

代码:

class Solution(object):
    def singleNumber(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        num = 0
        for i in nums:
            num = num ^ i
        return num

def stringToIntegerList(input):
    return json.loads(input)

def intToString(input):
    if input is None:
        input = 0
    return str(input)

def main():
    import sys
    def readlines():
        for line in sys.stdin:
            yield line.strip(‘
‘)
    lines = readlines()
    while True:
        try:
            line = lines.next()
            nums = stringToIntegerList(line)
            
            ret = Solution().singleNumber(nums)

            out = intToString(ret)
            print out
        except StopIteration:
            break

if __name__ == ‘__main__‘:
    main()



以上是关于leecode第二天-使用异或找出数组中的非重复元素的主要内容,如果未能解决你的问题,请参考以下文章

LeeCode 第1题

找出数组中唯一重复的数(转)

LeeCode 无重复字符串的最长子串

LeeCode 无重复字符串的最长子串

Leecode 496. 下一个更大元素 I——Leecode每日一题系列

找出不重复数字