380. O(1) 时间插入、删除和获取随机元素
小于 1 分钟
380. O(1) 时间插入、删除和获取随机元素
中等class RandomizedSet {
    int[] nums;
    Random random;
    Map<Integer,Integer> map;
    int index;
    public RandomizedSet() {
        nums = new int[200010];
        random = new Random();
        map = new HashMap<>();
        index = -1;
    }
    public boolean insert(int val) {
        if(map.containsKey(val)){
            return false;
        }else {
            nums[++index] = val;
            map.put(val,index);
            return true;
        }
    }
    public boolean remove(int val) {
        if(map.containsKey(val)){
            // map 中删除,获得旧值索引
            Integer idx = map.remove(val);
            // index 指向索引移动到旧数据上,k-v 改变
            if(idx != index){
                map.put(nums[index],idx);
            }
            // 旧索引的值为新索引所在的值,index--
            nums[idx] = nums[index--];
            return true;
        }else {
            return false;
        }
    }
    public int getRandom() {
        return nums[random.nextInt(index + 1)];
    }
}
 Powered by  Waline  v2.15.5