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

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


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

代码如下:

cpp 复制代码
class RandomizedSet {
public:
    vector<int> arr;
    unordered_map<int,int> m;

public:
    RandomizedSet() {

    }
    
    bool insert(int val) {
        if(m.find(val)!=m.end())
            return false;

        arr.push_back(val);
        m[val]=arr.size()-1;
        return true;
    }
    
    bool remove(int val) {
        if(m.find(val)==m.end())
            return false;
        
        int valPos=m[val];
        arr[valPos]=arr[arr.size()-1];
        m[arr[valPos]]=valPos;
        arr.pop_back();
        
        m.erase(val);
        return true;
    }
    
    int getRandom() {
        return arr[rand()%arr.size()];
    }
};

/**
 * Your RandomizedSet object will be instantiated and called as such:
 * RandomizedSet* obj = new RandomizedSet();
 * bool param_1 = obj->insert(val);
 * bool param_2 = obj->remove(val);
 * int param_3 = obj->getRandom();
 */
相关推荐
纵有疾風起5 小时前
C++—vector:vecor使用及模拟实现
开发语言·c++·经验分享·开源·stl·vector
爱凤的小光8 小时前
图漾GM461-E1相机专栏
c++
qwepoilkjasd9 小时前
C++智能指针介绍
c++
·白小白9 小时前
力扣(LeetCode) ——43.字符串相乘(C++)
c++·leetcode
咬_咬9 小时前
C++仿muduo库高并发服务器项目:Poller模块
服务器·开发语言·c++·epoll·muduo
FMRbpm9 小时前
链表5--------删除
数据结构·c++·算法·链表·新手入门
Kimser10 小时前
QT C++ QWebEngine与Web JS之间通信
javascript·c++·qt
QT 小鲜肉10 小时前
【QT/C++】Qt样式设置之CSS知识(系统性概括)
linux·开发语言·css·c++·笔记·qt
Elias不吃糖10 小时前
NebulaChat 框架学习笔记:深入理解 Reactor 与多线程同步机制
linux·c++·笔记·多线程
转基因11 小时前
命名空间与匿名空间
c++