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();
 */
相关推荐
橘子132 分钟前
C++实战:搜索引擎项目(二)
开发语言·c++·搜索引擎
应用市场33 分钟前
Qt C++ 图形绘制完全指南:从基础到进阶实战
开发语言·c++·qt
青草地溪水旁1 小时前
设计模式(C++)详解—单例模式(2)
c++·单例模式
bkspiderx1 小时前
C++时区操作全版本指南(含C++03/C++11-17/C++20)
linux·开发语言·c++·c++20·时区
序属秋秋秋2 小时前
《C++进阶之STL》【哈希表】
数据结构·c++·stl·哈希算法·散列表·哈希表·哈希
青草地溪水旁2 小时前
设计模式(C++)详解——建造者模式(1)
c++·设计模式·建造者模式
自动驾驶小卡7 小时前
boost::circular_buffer的使用方法简介
c++·boost·circular_buffer
睡不醒的kun9 小时前
leetcode算法刷题的第三十二天
数据结构·c++·算法·leetcode·职场和发展·贪心算法·动态规划
乔宕一11 小时前
stm32 链接脚本没有 .gcc_except_table 段也能支持 C++ 异常
c++·stm32·嵌入式硬件
SuperCandyXu11 小时前
P3205 [HNOI2010] 合唱队-普及+/提高
c++·算法·洛谷