[Leetcode]Single Number

Given an array of integers, every element appears twice except for one. Find that single one.

Note:

Your algorithm should have a linear runtime complexity. Could you implement it without using extra memory?

找到数组中只出现过一次的元素,其他元素都出现过两次~可以用位操作异或的性质, 因为两个相同的数异或的结果为0,可以对数组的所有元素进行异或,重复出现两次的元素会互相抵消,最后剩下的那个元素就是只出现一次的元素,时间复杂度为O(n)~

class Solution:
    # @param A, a list of integer
    # @return an integer
    def singleNumber(self, A):
        if A is None or len(A) == 0: return 0
        res = A[0]
        for i in xrange(1, len(A)):
            res ^= A[i]
        return res

还看到一个只有一行代码的python解法,代码如下~  reduce(func, A) 代表 func(func(A[0], A[1]), A[2])... 而operator模块提供了一系列的函数操作,比如,operator.add(x, y)等于x+y;operator.xor相当于x ^ y~所以下面的reduce function返回了A中所有元素的异或结果,也就是A中只出现了一次的元素~

class Solution:
    # @param A, a list of integer
    # @return an integer
    def singleNumber(self, A):
        return reduce(operator.xor, A)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值