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

实现RandomizedSet 类:

RandomizedSet() 初始化 RandomizedSet 对象

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

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

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

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

字节面试遇到过的题

考虑删除的时候把最后一个数换到当前要删除的位置

cpp 复制代码
class RandomizedSet {
	vector<int>v;
	unordered_map<int,int>mp1;
public:
	
    RandomizedSet() {
        v.clear();
        mp1.clear();
    }
    
    bool insert(int val) {
        if(mp1.find(val)==mp1.end())
        {
			v.push_back(val);
			mp1[val]=v.size()-1;
			return true;
		}
		return false;
    }
    
    bool remove(int val) {
        if(mp1.find(val)!=mp1.end())
        {
        	int end_num=v.back();
        	v.pop_back();
        	int pos=mp1[val];
        	v[pos]=end_num;
        	mp1[end_num]=pos;
        	mp1.erase(val);
			return true;
		}
		return false;
    }
    
    int getRandom() {
        int pos=rand()%v.size();
        return v[pos];
    }
};
相关推荐
王老师青少年编程15 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮16 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说16 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove16 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung17 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了17 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL17 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰17 小时前
C++ 排列组合完整指南
开发语言·c++·算法
代码中介商18 小时前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法
foundbug99918 小时前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab