算法(TS):只出现一次的数字

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

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

上题要求时间复杂度为 O(n),空间复杂度为O(1)

解法一:维护一个 Set 对象

创建一个空的 Set 对象,遍历数组 nums,每遍历出一个 num,便在 Set 对象中查找是否存在它,不存在则加入,存在则删除,等数组遍历结束,Set 对象中剩下的就是只出现一次的数字。

ts 复制代码
function singleNumber(nums: number[]): number {
  const uniqueSet = new Set<number>()
  for (const num of nums) {
    if (uniqueSet.has(num)) {
      uniqueSet.delete(num)
    } else {
      uniqueSet.add(num)
    }
  }

  return [...uniqueSet][0]
}

存在一次遍历数组,因此时间复杂度为 O(n),uniqueSet.size的最大值为 n/2,最小为 1, 空间复杂度为O(n)

解法二:位运算符(异或)

异或运算符有下面 3 个特性

  1. a ^ 0 = a,即,任何数与数字 0 异或,得到的结果都等于它本身
  2. a ^ a = 0,即,任何数与自身异或,得到的结果都等于 0
  3. a ^ b ^ c = a ^ c ^ b,异或运算符,满足交换率

遍历 nums,让数组中的数字两两异或,最终得到的结果便是数组中只出现一次的数字

ts 复制代码
function singleNumber(nums: number[]): number {
  let uniqueNumber = 0

  for (const num of nums) {
    uniqueNumber ^= num
  }

  return uniqueNumber
}

存在一次遍历数组,因此时间复杂度为 O(n),没有额外的中间量空间复杂度为O(1)

相关推荐
hunteritself3 分钟前
GPT Image2 + Seedance 2.0:3 小时从剧本到 AI 互动影游,深度实测复盘
前端·数据库·人工智能·深度学习·transformer
Dr.Zeus6 分钟前
从电芯到系统:BMS算法视角下的电池热管理深度解析作者署名
算法·能源
ulias2129 分钟前
leetcode热题 - 6
linux·算法·leetcode
独秀不如众秀10 分钟前
前端页面引擎协议:由浅入深——从 30 行到 vform3 的演化之路
前端
七颗糖很甜12 分钟前
卫星通信遇到“太空天气”会怎样---电离层闪烁对卫星通信的影响
大数据·python·算法
学网安的肆伍19 分钟前
【044-WEB攻防篇】PHP应用&SQL盲注&布尔回显&延时判断&报错处理&增删改查方式
前端·sql·php
小凡子空白在线学习23 分钟前
工作拆分so总结
java·jvm·算法
88号技师24 分钟前
2026年2月新锐一区SCI-完整家庭互动优化算法Undivided Family Interaction Algorithm-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
八号当铺36 分钟前
从 Prompt 到 AI 工程化:理解 Rules、Skills 与 Agent
前端·ai编程·cursor
李日灐36 分钟前
【优选算法5】位运算经典算法面试题
后端·算法·面试·位运算