zoukankan      html  css  js  c++  java
  • Insert Delete GetRandom O(1)

    2018-07-15 18:36:29

    问题描述:

    问题求解:

        private ArrayList<Integer> ls;
        private HashMap<Integer, Integer> map;
        private Random rand;
    
        /** Initialize your data structure here. */
        public RandomizedSet() {
            ls = new ArrayList<>();
            map = new HashMap<>();
            rand = new Random();
        }
    
        /** Inserts a value to the set. Returns true if the set did not already contain the specified element. */
        public boolean insert(int val) {
            if (map.containsKey(val)) return false;
            ls.add(val);
            map.put(val, ls.size() - 1);
            return true;
        }
    
        /** Removes a value from the set. Returns true if the set contained the specified element. */
        public boolean remove(int val) {
            if (!map.containsKey(val)) return false;
            int idx = map.get(val);
            if (idx != ls.size() - 1) {
                int temp = ls.get(ls.size() - 1);
                ls.set(idx, temp);
                map.put(temp, idx);
            }
            map.remove(val);
            ls.remove(ls.size() - 1);
            return true;
        }
    
        /** Get a random element from the set. */
        public int getRandom() {
            return ls.get(rand.nextInt(ls.size()));
        }
    
  • 相关阅读:
    590. N 叉树的后序遍历
    CF605E
    网络流水题题单
    wqs二分的边界
    luoguP6326 Shopping
    【THUWC2020】工资分配
    CF1336简要题解
    「PKUWC2020」最小割
    洛谷P4895 独钓寒江雪
    省选联考2020简要题解
  • 原文地址:https://www.cnblogs.com/hyserendipity/p/9314470.html
Copyright © 2011-2022 走看看