【 每天学习一点算法 2026/04/06】常数时间插入、删除和获取随机元素

每天学习一点算法 2026/04/06

题目:常数时间插入、删除和获取随机元素

实现RandomizedSet 类:

RandomizedSet() 初始化 RandomizedSet 对象

bool insert(int val) 当元素 val 不存在时,向集合中插入该项,并返回 true ;否则,返回 false 。

bool remove(int val) 当元素 val 存在时,从集合中移除该项,并返回 true ;否则,返回 false 。

int getRandom() 随机返回现有集合中的一项(测试用例保证调用此方法时集合中至少存在一个元素)。每个元素应该有 相同的概率 被返回。

你必须实现类的所有函数,并满足每个函数的 平均 时间复杂度为 O(1) 。

这个题还是比较简单的,关键在于如何实现 时间复杂度为 O(1)getRandom()

数组可以轻松实现 O(1)getRandom() 但是 insert()remove()就不行了,需要遍历查找

我用 Set 可以是实现 O(1)insert()remove(),但是 getRandom() 如果要返回随即元素就必须得遍历,因为 Set 不能直接通过下标取值。

那么我们只能维护一个 数组 使用 Map 来记录元素的对应下标 ,注意我们删除的时候需要将最后一项放在删除下标出,然后再删除最后一项,这样就可以保证其他元素的下标不变。

typescript 复制代码
class RandomizedSet {
  map: Map<number, number> // Map<元素, 下标>
  arr: number[] // 存放元素的数组
  constructor() {
    // 初始化
    this.map = new Map()
    this.arr = []
  }

  insert(val: number): boolean {
    if (this.map.has(val)) {
      return false
    } else {
      // 插入元素
      this.map.set(val, this.arr.length)
      this.arr.push(val)
      return true
    }
  }

  remove(val: number): boolean {
    if (this.map.has(val)) {
      // 删除元素
      const index = this.map.get(val)
      // 用末尾元素替换目标元素下标处的值
      this.arr[index] = this.arr[this.arr.length - 1]
      // 删除末尾元素
      this.arr.pop()
      // 更新之前末尾元素的下标
      this.map.set(this.arr[index], index)
      // 删除目标元素
      this.map.delete(val)
      return true
    } else {
      return false
    }
  }

  getRandom(): number {
    // 返回随机值
    const random = Math.floor(Math.random() * this.arr.length)
    return this.arr[random]
  }
}

题目来源:力扣(LeetCode)

相关推荐
三品吉他手会点灯1 小时前
C语言学习笔记 - 20.C编程预备计算机专业知识 - 变量为什么必须的初始化【重点】
c语言·笔记·学习
sakiko_1 小时前
UIKit学习笔记1-创建项目(使用UIKit)、使用组件
笔记·学习
Old Uncle Tom2 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆2 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移2 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业2 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
星幻元宇VR4 小时前
VR航空航天科普设备【VR时空直升机】
科技·学习·安全·生活·vr
_李小白4 小时前
【android opencv学习笔记】Day 2: Mat类(图片数据结构体)
android·opencv·学习
智者知已应修善业4 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
harder3215 小时前
RMP模式的创新突破
开发语言·学习·ios·swift·策略模式