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();
 */
相关推荐
阳光_你好21 分钟前
请详细说明opencv/c++对图片缩放
c++·opencv·计算机视觉
杰克逊的黑豹29 分钟前
不再迷茫:Rust, Zig, Go 和 C
c++·rust·go
Y.O.U..43 分钟前
今日八股——C++
开发语言·c++·面试
Zhichao_971 小时前
【UE5 C++课程系列笔记】33——商业化Json读写
c++·ue5
云边有个稻草人2 小时前
【C++】第八节—string类(上)——详解+代码示例
开发语言·c++·迭代器·string类·语法糖auto和范围for·string类的常用接口·operator[]
惊鸿一博2 小时前
c++ &&(通用引用)和&(左值引用)区别
开发语言·c++
nuo5342023 小时前
黑马 C++ 学习笔记
c语言·c++·笔记·学习
DARLING Zero two♡3 小时前
C++类间的 “接力棒“ 传递:继承(上)
开发语言·c++·继承·里氏替换原则
会讲英语的码农3 小时前
如何学习C++以及C++的宏观认知
开发语言·c++·学习
Merokes11 小时前
关于Gstreamer+MPP硬件加速推流问题:视频输入video0被占用
c++·音视频·rk3588