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;
    }
}
相关推荐
小O的算法实验室20 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
郭涤生21 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿21 小时前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz1 天前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能1 天前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****1 天前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能1 天前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能1 天前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo1 天前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ01 天前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法