LeetCode 260. 只出现一次的数字 III

更多题解尽在 https://sugar.matrixlab.dev/algorithm 每日更新。

组队打卡,更多解法等你一起来参与哦!

LeetCode 260. 只出现一次的数字 III ,难度中等

位运算

解题思路:

  • 根据相同的数字异或结果为 0 的特性,我们可以计算出两个只出现一次的数字异或的结果,但是还无法找到具体是哪两个数字。
  • 找出异或结果中任意一位为 1 的位置,利用这一位将数组分为两组;一组当前位为 0,另一组当前位为 1,这样两个只出现一次的数字会被分到不同的组中,其他所有成对的数字仍会被异或抵消为 0。
Java 复制代码
class Solution {
    public int[] singleNumber(int[] nums) {
        int[] result = new int[2];
        
        // 异或所有数字,得到两个不同数字的异或结果
        int xor = 0;
        for (int num : nums) {
            xor ^= num;
        }
        
        // 利用 xor & (-xor) 找出最低位的 1
        int diff = xor & (-xor);

        // 分组异或,num & diff 与运算区分出第 diff 位是否相同,进而将整个 num 分为两组
        for (int num : nums) {
            if ((num & diff) == 0) {
                result[0] ^= num;
            } else {
                result[1] ^= num;
            }
        }

        return result;
    }
}
相关推荐
圣保罗的大教堂8 分钟前
leetcode 2872. 可以被 K 整除连通块的最大数目 困难
leetcode
铅笔小新z11 分钟前
【C语言—数据结构】8种高效排序算法:从入门到实战
数据结构·算法·排序算法
AKDreamer_HeXY14 分钟前
AtCoder Beginner Contest 434 C-E 题解
c++·算法·前缀和·图论·差分·atcoder
roman_日积跬步-终至千里21 分钟前
【模式识别与机器学习(4)】主要算法与技术(中篇:概率统计与回归方法)之线性回归模型
算法·机器学习
小李小李快乐不已24 分钟前
图论理论基础(2)
java·开发语言·c++·算法·图论
点云SLAM26 分钟前
四元数 (Quaternion)微分-单位四元数 q(t) 的导数详细推导(10)
算法·计算机视觉·机器人·slam·imu·四元数·单位四元数求导
学学学无无止境26 分钟前
力扣-颠倒二进制位
leetcode
秋邱27 分钟前
2025 年突破性科技:大模型驱动的实时多模态数据流处理系统
人工智能·科技·算法·机器学习
sin_hielo28 分钟前
leetcode 2141
数据结构·算法·leetcode
qq_4335545432 分钟前
C++ 最长单调子序列
c++·算法·图论