题解 | #数组中只出现一次的数字#

数组中只出现一次的数字

https://www.nowcoder.com/practice/e02fdb54d7524710a7d664d082bb7811

这道题有一个前置题目,就是将本题的条件改为“一个整型数组里除了一个数字n之外,其他的数字都出现了两次”。

先来解决这道前置题目,可以想到用异或运算解决,出现两次的数字异或之后为0,而0^n = n,所以最后得到的数一定是n。

接下来解决本题。本题有两个数字只出现一次,所以依次异或一遍得到的是两个数字做异或的结果tmp。

我们考虑异或操作是一个位运算,当两个数字的同一位不同时,异或得到该位为1,否则为0。

所以,我们可以从tmp中选出为1的一位,然后将原数组分为两组,第一组为该位为1,第二组为该位为0,这样就能将两个只出现一次的数分到两个数组中,且这两个数组都满足“一个整型数组里除了一个数字n之外,其他的数字都出现了两次”。

class Solution {
public:
    void FindNumsAppearOnce(vector<int> data,int* num1,int *num2) {
        int sum = 0;
        for (auto &i: data) sum ^= i;
        int bt = 0;
        while (((sum >> bt) & 1) == 0) bt++;
        int n1 = 0, n2 = 0;
        for (auto &i: data) {
            if ((i >> bt) & 1) {
                n1 ^= i;
            }
            else {
                n2 ^= i;
            }
        }
        *num1 = n1;
        *num2 = n2;
    }
};

全部评论

相关推荐

牛客77743221...:做一段时间,公司出钱送你去缅甸和泰国旅游
点赞 评论 收藏
分享
10-22 15:25
门头沟学院 C++
种花网友小松:求求你别发了,我几乎都快嫉妒得疯了,倒在床上蒙住被子就开始抱着枕头尖叫流泪,嘴里一边喊着卧槽卧槽,一边又忍着,我边发边哭,打字的手都是抖的,后来我的手抖得越来越厉害,从心头涌起的思想、情怀和梦想,这份歆羡和悔恨交织在一起,我的笑还挂在脸上,可是眼泪一下子就掉下来了。求你了别发了,我生活再难再穷我都不会觉得难过,只有你们发这种东西的时候,我的心里像被刀割一样的痛,打着字泪水就忍不住的往下流。
我的求职进度条
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务