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;
    }
}
相关推荐
techdashen2 分钟前
Async Rust 近况补课:从 `async-trait` 到原生 async trait
网络·算法·rust
一行代码一行诗++3 分钟前
循环的嵌套
数据结构·算法
天真小巫8 分钟前
六年之约-2026.5.22
职场和发展
玖釉-11 分钟前
C++ 中的矩阵介绍:以二维矩阵查找为例
c++·windows·算法·矩阵
ECT-OS-JiuHuaShan12 分钟前
存在是微分张量积,标量是参数但不可能是本质。还原论泛化,是语义劫持和以偏概全的逻辑谋杀伪科学庞氏骗局
数据库·人工智能·算法·机器学习·数学建模
CQU_JIAKE15 分钟前
5.22【A】
算法
2601_9578822427 分钟前
多账号流量内容运营的数据归因与ROI优化:从经验驱动到算法决策的技术转型
算法·产品运营·内容运营
bug大湿30 分钟前
麦阵波束算法——MVDR
算法·音频
ʚ希希ɞ ྀ30 分钟前
dp反思与总结
算法·leetcode·动态规划
简简单单做算法32 分钟前
基于模糊神经网络的一维时间序列预测算法matlab仿真
神经网络·算法·matlab·一维时间序列预测·模糊神经网络