优选算法_位运算_只出现一次的数字3_C++

一.题目解析

有一个数组,里面的数都是成双成对的,只有两个是单独的

算法讲解:位运算

我们可以利用消消乐A^A=0来消除相同的数字,只剩下a^b=tmp

再循环进行异或消消乐就可以再AB数组分别得到ab

二.代码编写

cpp 复制代码
class Solution {
public:
    vector<int> singleNumber(vector<int>& nums) {
        int tmp=0;
        for(int num:nums)
        {
            tmp^=num;
        }
        int x=0;
        if(tmp==INT_MIN)
        {
            x=tmp;
        }
        else
        {
            x=tmp&(-tmp);
        }
        
        vector<int>a,b;
        for(auto num:nums)
        {
            if((num&x)!=0)a.push_back(num);//第x位是1的*****
            else b.push_back(num);//第x位是0的
        }
        int num1=0,num2=0;
        for(auto x:a)
        {
            num1^=x;
        }
        for(auto y:b)
        {
            num2^=y;
        }
        return {num1,num2};
    }
};
相关推荐
8Qi821 小时前
LeetCode 5:最长回文子串(Longest Palindromic Substring)—— 题解
算法·leetcode·职场和发展·动态规划
Adorable老犀牛21 小时前
Prometheus 常用告警规则 rules.yml
开发语言·prometheus·exporter·nodeexpoeter
j7~21 小时前
【算法】专题一:双指针之移动零,复写零,快乐数
数据结构·c++·算法·双指针·快乐数·移动零·复写零
lqqjuly21 小时前
KAN 网络深度解析
算法
睡一觉就好了。21 小时前
C++11(三)
c++
阿里matlab建模师21 小时前
【机场停机位分配】matlab实现基于遗传算法的机场停机位分配优化研究
开发语言·算法·数学建模·matlab·全国大学生数学建模竞赛
xiaoshuaishuai821 小时前
C# Avalonia 依赖属性与WPF的区别
开发语言·c#·wpf
一碗白开水一21 小时前
【训练技巧】bash: conda: command not found:conda 没有适配环境
开发语言·conda·bash
一晌小贪欢21 小时前
第22节:相关性分析——协方差、相关系数与热力图解读
开发语言·python·数据分析·pandas·数据可视化
keykey6.21 小时前
循环神经网络(RNN)与序列模型:让AI学会“记忆“
开发语言·人工智能·深度学习·机器学习