Skip to content

Latest commit

 

History

History
44 lines (37 loc) · 782 Bytes

380_insertAndDeleteO_1.md

File metadata and controls

44 lines (37 loc) · 782 Bytes

Vector + Map

Code

class RandomizedSet {
private:
    vector<int> nums;
    unordered_map<int, int> mp;

public:
    RandomizedSet()
    {
    }

    bool insert(int val)
    {
        if (mp.count(val))
            return false;
        nums.push_back(val);
        mp[val] = nums.size() - 1;
        return true;
    }

    bool remove(int val)
    {
        if (mp.count(val) == 0)
            return false;
        int last = nums.back();
        mp[last] = mp[val];
        nums[mp[val]] = last;
        nums.pop_back();
        mp.erase(val);
        return true;
    }

    int getRandom()
    {
        return nums[rand() % nums.size()];
    }
};