(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;
    }
}

思路

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

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

相关推荐
王老师青少年编程15 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【删数问题】:删数问题2
c++·算法·贪心·csp·信奥赛
hanbr15 小时前
Leetcode刷题总结(1)
算法·leetcode·职场和发展
B站_计算机毕业设计之家15 小时前
计算机毕业设计:Python股票投资辅助决策系统 django框架 request爬虫 协同过滤算法 数据分析 可视化 大数据 大模型(建议收藏)✅
爬虫·python·深度学习·算法·django·flask·课程设计
_日拱一卒15 小时前
LeetCode:随机链表的复制
算法·leetcode·链表
菜菜的顾清寒15 小时前
力扣笔记自用
笔记·算法·leetcode
故事还在继续吗15 小时前
C++11关键特性
开发语言·c++·算法
zzzsde15 小时前
【Linux】线程概念与控制(2)线程控制与核心概念
linux·运维·服务器·开发语言·算法
Gh0st_Lx15 小时前
【8】分类任务原理
算法·分类·数据挖掘
WolfGang00732115 小时前
代码随想录算法训练营 Day45 | 图论 part03
算法·图论
a里啊里啊15 小时前
软考-软件评测师:知识点整理(六)——数据结构与算法
数据结构·算法·链表·软考·软件评测师