1.8 面试经典150题 O(1)时间插入删除和获取随机元素

O(1)时间插入删除和获取随机元素

实现RandomizedSet 类:

  • RandomizedSet() 初始化 RandomizedSet 对象
  • bool insert(int val) 当元素 val 不存在时,向集合中插入该项,并返回 true ;否则,返回 false
  • bool remove(int val) 当元素 val 存在时,从集合中移除该项,并返回 true ;否则,返回 false
  • int getRandom() 随机返回现有集合中的一项(测试用例保证调用此方法时集合中至少存在一个元素)。每个元素应该有 相同的概率 被返回。

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

python 复制代码
class RandomizedSet:

    def __init__(self):
        self.map = {}

    def hasKey(self, val: int) -> bool:
        return val in self.map

    def insert(self, val: int) -> bool:
        if self.hasKey(val): return False
        self.map.update(
            {val: val}
        )
        return True

    def remove(self, val: int) -> bool:
        if not self.hasKey(val): return False
        del self.map[val]
        return True

    def getRandom(self) -> int:
        keys = list(self.map.keys())
        index = int(random.random() * len(keys))
        return keys[index]

# Your RandomizedSet object will be instantiated and called as such:
# obj = RandomizedSet()
# param_1 = obj.insert(val)
# param_2 = obj.remove(val)
# param_3 = obj.getRandom()

考虑使用字典类型解决

相关推荐
weixin_307779131 小时前
AWS Lambda解压缩S3 ZIP文件流程
python·算法·云计算·aws
独行soc8 小时前
2025年渗透测试面试题总结-18(题目+回答)
android·python·科技·面试·职场和发展·渗透测试
S01d13r9 小时前
gunicorn + flask 处理高并发请求
python·flask·gunicorn
杜子不疼.9 小时前
《Python列表和元组:从入门到花式操作指南》
开发语言·python
pan0c239 小时前
数据处理与统计分析 —— numpy入门
python·numpy
max5006009 小时前
基于桥梁三维模型的无人机检测路径规划系统设计与实现
前端·javascript·python·算法·无人机·easyui
秋氘渔10 小时前
综合案例:Python 函数知识整合 — 学生成绩管理系统
开发语言·python
AI 嗯啦11 小时前
SQL详细语法教程(三)mysql的函数知识
android·开发语言·数据库·python·sql·mysql
databook11 小时前
把数学对象画出来:Manim Mobject类库速查手册
python·数学·动效
图灵学术计算机论文辅导12 小时前
傅里叶变换+attention机制,深耕深度学习领域
人工智能·python·深度学习·计算机网络·考研·机器学习·计算机视觉