【位运算】Leetcode 只出现一次的数字 ||

题目解析

137. 只出现一次的数字 II

在这里插入图片描述


算法讲解

在这里插入图片描述
nums中要么一个数字出现三次,一个数字出现一次,按照比特位来说只可能出现上面的四种情况: 3n个0 + 0 或者 3n个0 + 1 或者 3n个1 + 0 或者 3n个1 + 1,它们相加的结果依次是0, 1, 3n, 3n+1,让当前这个比特位相加的结果%3可以的看出结果和只出现一次的数字上面的比特位一样

所以我们算法就是:求出数组中所有数字当前比特位之和,然后如果结果% 3等于1,就让ret当前的这个比特位置1即可,最终遍历结束ret的32个比特位之后,就找到了只出现一次的数字

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int ret = 0;
        for(int i = 0; i < 32; i++)
        {
            int sum = 0;
            //将每个数字上当前比特位提取出来 相加
            for(auto& n : nums)
            {
                sum += ((n >> i) & 1);
            }
            //判断单身狗数字的当前比特位是否需要处理
            if(sum % 3) ret |= (1 << i);
        }
        return ret;
    }
};

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值