只出现一次的数字---异或妙解

题目

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

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

示例 1 :

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

**输出:**1

示例 2 :

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

**输出:**4

示例 3 :

**输入:**nums = [1]

**输出:**1

提示:

  • 1 <= nums.length <= 3 * 104
  • -3 * 104 <= nums[i] <= 3 * 104
  • 除了某个元素只出现一次以外,其余每个元素均出现两次。

思路

实际上思路很简单,就是只有一个元素是只出现一次的,那么可以出现俩次的数字异或之后一定会抵消,因为相同的数字异或后为0,所以遍历一次全部异或即可

代码

java 复制代码
class Solution {
    public int singleNumber(int[] nums) {
        int single = 0;
        for (int num : nums) {
            single ^= num;
        }
        return single;
    }
}
相关推荐
啊哦呃咦唔鱼16 分钟前
LeetCode双指针合集
算法·leetcode·职场和发展
WolfGang00732137 分钟前
代码随想录算法训练营 Day37 | 动态规划 part10
算法·动态规划
baizhigangqw39 分钟前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(二)
算法·启发式算法·web app
alphaTao40 分钟前
LeetCode 每日一题 2026/4/13-2026/4/19
算法·leetcode·职场和发展
灵智实验室44 分钟前
PX4姿态解算技术详解(四):姿态更新/递推与共锥补偿
算法·无人机·px 4
良木生香1 小时前
【C++初阶】C++编程基石:编码表&&STL的入门指南
c语言·开发语言·数据结构·c++·算法
秋91 小时前
学霸圈公认的 10 种高效学习习惯:从低效到顶尖的底层逻辑
人工智能·学习·算法
岁岁种桃花儿1 小时前
面试全系列之【Kafka】之【经典版】系列
面试·职场和发展·kafka
极简车辆控制1 小时前
泵控式电液主动悬架系统分层控制研究_论文复现
算法·汽车
扶苏xw1 小时前
【分组背包】
算法·动态规划