[Leetcode] 数组中数字出现的次数

2020-04-28  本文已影响0人  丶噗噗噗噗噗

数组中数字出现的次数

来源: Leetcode-数组中数字出现的次数

1. 解题思路

2. 代码

class Solution:
    def singleNumbers(self, nums: List[int]) -> List[int]:
        ret = 0  # 所有数字异或的结果
        a = 0
        b = 0
        for n in nums:
            ret ^= n
        # 找到第一位不是0的
        h = 1
        while(ret & h == 0):
            h <<= 1
        for n in nums:
            # 根据该位是否为0将其分为两组
            if (h & n == 0):
                a ^= n
            else:
                b ^= n

        return [a, b]
上一篇下一篇

猜你喜欢

热点阅读