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();
 */
相关推荐
澈2074 小时前
深入浅出C++滑动窗口算法:原理、实现与实战应用详解
数据结构·c++·算法
A.A呐4 小时前
【C++第二十九章】IO流
开发语言·c++
ambition202424 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
kebeiovo5 小时前
atomic原子操作实现无锁队列
服务器·c++
Yungoal5 小时前
常见 时间复杂度计算
c++·算法
6Hzlia5 小时前
【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解
c++·leetcode·矩阵
Ricky_Theseus6 小时前
C++右值引用
java·开发语言·c++
吴梓穆7 小时前
UE5 c++ 常用方法
java·c++·ue5
云栖梦泽7 小时前
Linux内核与驱动:9.Linux 驱动 API 封装
linux·c++
Morwit7 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展