Leetcode Single Number III

class Solution {
public:
    unsigned long intmax = 2147483647;
    vector<int> singleNumber(vector<int>& nums) {
        // 
        // 相同的数亦或的结果是0,不同的数亦或的结果不一样。
        // 第一遍遍历得到两个不同的数的亦或。
        // 通过 num & (~num + 1) 得到num 的最后一位不同的数,以此来区分在nums数组中哪一位不是A,哪一位不是B.
        // 也就是说在nums中如果不让B参与遍历亦或,那么最后得到的结果便是A,同理可以得到B.
        // 代码如下.

        // 这里是第一轮遍历,得到了nums数组中A Xor B 的值.
        int aXorB = 0;
        int size = nums.size();
        for (int i = 0; i < size; ++i) {
            aXorB ^= nums[i];
        }

        int flag = aXorB & (-aXorB + 1);
        // 如果 num 是A或者B里的一个, 则A & flag 和 B & flag 必然是一个为0, 一个是1, 以此来区分A和B.

        int A = 0, B = 0;
        for (int i = 0; i < size; ++i) {
            if (nums[i] & flag) {
                // 将那些和flag亦或不为0的项放在一起亦或,这样得到的结果便是那些有两个的数和只有一个的A或者B
                A ^= nums[i];
            } else {
                // 将那些和flag亦或为0的项放在一起亦或,这样得到的结果便是那些有两个的数和只有一个的A或者B
                B ^= nums[i];
            }
        }
        vector<int> res;
        res.push_back(A);
        res.push_back(B);
        return res;
    }
};

Leetcode Single Number III
挺好的一个思想。Mark一下。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值