260. 只出现一次的数字 III

题目

题解

题解一

  • 直接使用 HashSet 判断
java 复制代码
class Solution {
    public int[] singleNumber(int[] nums) {

        Set<Integer> set = new HashSet<>();
        for (int num : nums) {
            if (set.contains(num)) {
                set.remove(num);
            } else {
                set.add(num);
            }
        }
        int[] res = new int[2];
        int index = 0;
        for (Integer i : set) {
            res[index++] = i;
        }
        return res;
    }
}

题解二

  • 对数组所有元素求异或,得到的值为那两个不同元素的异或结果
  • 明确那两个数肯定不同,所以肯定有的位数异或后结果为 1
    • 假如第 x 位异或的结果为 1,即所有数的 x 位异或结果为 1
    • 找到 x 的最小值
  • 现在数组中只有两类数:x 位为 0 的,和 x 位为 1 的,并且这两个不同的数的 x 位还不同
  • 通过 & 操作,将数组氛围两类
  • 最后问题拆解为 136.只出现一次的数字
java 复制代码
class Solution {
    public int[] singleNumber(int[] nums) {

        // 两个不同数的异或值
        int tmp = 0;
        for (int num : nums) {
            tmp = tmp ^ num;
        }
        // 两个数不同,tmp 肯定不为 0,得到最后为 1 的位
        // 4  -> 100
        // -4 -> 11111111111111111111111111111100
        // 4 & -4 -> 100
        int fg = tmp & -tmp;

        // 数组里面所有数的该位要么是 0,要么是 1,且与运算之后最终结果是 1
        int res1 = 0;
        int res2 = 0;
        for (int num : nums) {
            if ((num & fg) == 0) {
                res1 = res1 ^ num;
            } else {
                res2 = res2 ^ num;
            }
        }
        return new int[]{res1, res2};
    }

}

本文由mdnice多平台发布

相关推荐
阿虎儿6 小时前
56条软件工程开发定律
程序员
程序员鱼皮8 小时前
Git WorkTree 是什么?凭什么能让 AI 编程效率翻倍?
git·ai·程序员·编程·ai编程
czkm8 小时前
AI有情绪吗?从AI夸我是写作领域大神说起
人工智能·程序员·ai编程
SimonKing12 小时前
AI编程工具装了一大堆,Skills 管理乱成粥?这个开源神器一招搞定!
java·后端·程序员
小兵张健1 天前
AI 带来的机遇,可能真的大于风险
程序员·openai·ai编程
WebInfra1 天前
Rsbuild 2.0 发布:即将支持 TanStack Start
前端·javascript·程序员
我就是马云飞1 天前
我废了!大厂10年的我面了20家公司,面试官让我回去等通知!
android·前端·程序员
橙某人1 天前
生产力悖论:AI Coding 的效率狂欢与秩序隐忧
程序员
阿祖zu1 天前
ZuSpaceX 赛博像素风个人主站开源
程序员·aigc