(leetcode)力扣100 96.只出现一次的数字(位运算)

题解

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

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

数据范围

1 <= nums.length <= 3 * 104

-3 * 104 <= nums[i] <= 3 * 104

除了某个元素只出现一次以外,其余每个元素均出现两次。

测试用例

示例1

java 复制代码
输入:nums = [2,2,1]

输出:1

示例 2 :

java 复制代码
输入:nums = [4,1,2,1,2]

输出:4

示例3

java 复制代码
输入:nums = [1]

输出:1

题解(时间On,空间O1)

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

思路

这道题怎么说呢,要是想到了位运算,确实特别简单,想不到的话抓耳挠腮(博主)。

因为异或满足这个规律,所以我们只需要把数组里的数按顺序异或一次,最后剩下的就是只出现过一次的数。

相关推荐
Lucky_ldy10 分钟前
C语言学习: 自定义类型—联合和枚举
c语言·学习·算法
gumichef10 分钟前
栈和队列(2)
数据结构·算法·链表
进击的荆棘12 分钟前
递归、搜索与回溯——综合(下)
c++·算法·leetcode·深度优先·dfs
不知名的忻13 分钟前
归并排序(Java)
java·算法·排序算法
YUDAMENGNIUBI3 小时前
day20_逻辑回归
算法·机器学习·逻辑回归
澈2077 小时前
C++并查集:高效解决连通性问题
java·c++·算法
旖-旎9 小时前
深搜练习(单词搜索)(12)
c++·算法·深度优先·力扣
企客宝CRM10 小时前
2026年中小企业CRM选型指南:企客宝CRM处于什么位置?
android·算法·企业微信·rxjava·crm
橙淮10 小时前
二叉树核心概念与Java实现详解
数据结构·算法
米罗篮10 小时前
DSU并查集 & 拓展欧几里得-逆元
c++·经验分享·笔记·算法·青少年编程