package 第02期.mca_01; import java.util.HashMap; // 测试链接 : https://leetcode.com/problems/insert-delete-getrandom-o1/ public class Problem02_InsertDeleteGetRandom { public class RandomizedSet { private HashMap keyIndexMap; private HashMap indexKeyMap; private int size; public RandomizedSet() { keyIndexMap = new HashMap(); indexKeyMap = new HashMap(); size = 0; } public boolean insert(int val) { if (!keyIndexMap.containsKey(val)) { keyIndexMap.put(val, size); indexKeyMap.put(size++, val); return true; } return false; } public boolean remove(int val) { if (keyIndexMap.containsKey(val)) { int deleteIndex = keyIndexMap.get(val); int lastIndex = --size; int lastKey = indexKeyMap.get(lastIndex); keyIndexMap.put(lastKey, deleteIndex); indexKeyMap.put(deleteIndex, lastKey); keyIndexMap.remove(val); indexKeyMap.remove(lastIndex); return true; } return false; } public int getRandom() { if (size == 0) { return -1; } int randomIndex = (int) (Math.random() * size); return indexKeyMap.get(randomIndex); } } }