LeetCode热题100--136. 只出现一次的数字--简单

题目

给你一个 非空 整数数组 nums ,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。

你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。

示例 1 :

输入:nums = [2,2,1]

输出:1

示例 2 :

输入:nums = [4,1,2,1,2]

输出:4

示例 3 :

输入:nums = [1]

输出:1

题解

java 复制代码
class Solution {
    public int singleNumber(int[] nums) {
        int ans = 0;
        for(int num: nums) {
            ans ^= num;
        }
        return ans;
    }
}

解析

出自:画解算法:136. 只出现一次的数字

java 复制代码
class Solution {
    public int singleNumber(int[] nums) {
        // 初始化结果变量 ans 为 0。
        // 因为任何数与 0 异或都等于它本身(a ^ 0 = a),所以 0 是异或运算的"单位元"。
        int ans = 0;
        
        // 遍历数组 nums 中的每一个元素 num
        for(int num: nums) {
            // 将当前数字 num 与 ans 进行异或运算,并将结果存回 ans
            // 利用异或的性质:
            //   1. 相同的数异或为 0:a ^ a = 0
            //   2. 异或满足交换律和结合律
            //   3. 0 ^ a = a
            // 因此,所有出现两次的数字会相互抵消(变成 0),最终只剩下那个只出现一次的数字
            ans ^= num;
        }
        
        // 循环结束后,ans 中保存的就是数组中唯一只出现一次的数字
        return ans;
    }
}
相关推荐
万添裁9 分钟前
huawei 机考
算法·华为·深度优先
IronMurphy7 小时前
【算法四十三】279. 完全平方数
算法
墨染天姬8 小时前
【AI】Hermes的GEPA算法
人工智能·算法
papership8 小时前
【入门级-数据结构-3、特殊树:完全二叉树的数组表示法】
数据结构·算法·链表
smj2302_796826528 小时前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
Beginner x_u9 小时前
链表专题:JS 实现原理与高频算法题总结
javascript·算法·链表
wxy不爱写代码9 小时前
C++多线程
面试·职场和发展
野生技术架构师11 小时前
金三银四面试总结篇,汇总 Java 面试突击班后的面试小册
java·面试·职场和发展
_深海凉_12 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展
ja哇12 小时前
大厂面试高频八股
java·面试·职场和发展