在做题中学习(32):只出现一次的数字 III

260. 只出现一次的数字 III - 力扣(LeetCode)

根据题目可知:有两个元素只出现一次,其余出现两次。

而在只出现一次的数字 I 里,只有一个元素出现一次,可以用异或的方式直接得到最后的答案,而此题中最后会得到两个不同数字异或后的值x。(a^b=x)

思路:

**1.**从x中获取第一个lowbit为1的位,因为两个数异或某一位结果为1的话,那么这两个数在这一位上的值必定不相同。

**2.**根据这个不相同,把原数组里的所有数分为两组,分别是 :这一位为0和这一位为1,再定义两个变量a b分别异或一组数,a b最终的结果就是两个只出现一次的元素。

注意:用unsigned是因为小心取lowbit溢出问题。

cpp 复制代码
class Solution {
public:
    vector<int> singleNumber(vector<int>& nums) 
    {
        unsigned int j=0;
        //最后异或得到的数字
        for(int i=0;i<nums.size();i++)
        {
            j^=nums[i];
        }
        //k拿到j最低位的1
        unsigned int k=j&(-j);
        //count是几,就是第几位有不同
        int count=0;
        while(k!=1)
        {
             k = k>>1;
             count++;
        }
        int a,b=0;
        //分组异或
        for(int i=0;i<nums.size();i++)
        {
            if(((nums[i]>>count)&1)==0)
            {
                a^=nums[i];
            }
            else
            {
                b^=nums[i];
            }
        }
        vector<int> v3;
        v3.push_back(a);
        v3.push_back(b);
        return v3;
    }
};
相关推荐
吴维炜6 分钟前
「Python算法」计费引擎系统SKILL.md
python·算法·agent·skill.md·vb coding
No0d1es14 分钟前
电子学会青少年软件编程(C语言)等级考试试卷(三级)2025年12月
c语言·c++·青少年编程·电子学会·三级
詩不诉卿33 分钟前
zephyr学习之自定义外部module记录
学习
浮游本尊35 分钟前
React 18.x 学习计划 - 第十三天:部署与DevOps实践
学习·react.js·状态模式
wdfk_prog1 小时前
[Linux]学习笔记系列 -- [drivers][dma]dmapool
linux·笔记·学习
电饭叔1 小时前
Tkinter Button 括号内的核心参数详解
python·学习
Σίσυφος19001 小时前
PCL Point-to-Point ICP详解
人工智能·算法
bjxiaxueliang1 小时前
一文掌握C/C++命名规范:风格、规则与实践详解
c语言·开发语言·c++
玄〤1 小时前
Java 大数据量输入输出优化方案详解:从 Scanner 到手写快读(含漫画解析)
java·开发语言·笔记·算法
weixin_395448912 小时前
main.c_cursor_0202
前端·网络·算法