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;
    }
}
相关推荐
老赵聊算法、大模型备案3 小时前
北京市生成式人工智能服务已备案信息公告(2025年12月11日)
人工智能·算法·安全·aigc
CoderYanger4 小时前
C.滑动窗口-求子数组个数-越长越合法——2799. 统计完全子数组的数目
java·c语言·开发语言·数据结构·算法·leetcode·职场和发展
厕所博士4 小时前
红黑树原理前置理解—— 2-3 树
算法·2-3树·红黑树原理理解前置
萌>__<新5 小时前
力扣打卡每日一题————除自身外所有元素的乘积
数据结构·算法
xu_yule5 小时前
算法基础—搜索(2)【记忆化搜索+BFS+01BFS+Floodfill]
数据结构·算法
s09071365 小时前
Xilinx FPGA使用 FIR IP 核做匹配滤波时如何减少DSP使用量
算法·fpga开发·xilinx·ip core·fir滤波
老马啸西风5 小时前
成熟企业级技术平台-10-跳板机 / 堡垒机(Bastion Host)详解
人工智能·深度学习·算法·职场和发展
子夜江寒6 小时前
逻辑回归简介
算法·机器学习·逻辑回归
软件算法开发6 小时前
基于ACO蚁群优化算法的多车辆含时间窗VRPTW问题求解matlab仿真
算法·matlab·aco·vrptw·蚁群优化·多车辆·时间窗
another heaven6 小时前
【软考 磁盘磁道访问时间】总容量等相关案例题型
linux·网络·算法·磁盘·磁道