leetcode 381. Insert Delete GetRandom O(1)
来源:互联网 发布:淘宝店铺主页封面 编辑:程序博客网 时间:2024/06/08 00:06
leetcode 381. Insert Delete GetRandom O(1) - Duplicates allowed
熟悉数据结构:Set Iterator next() 这些函数的用法
public class RandomizedCollection { ArrayList<Integer> nums;HashMap<Integer, Set<Integer>> locs;java.util.Random rand = new java.util.Random(); /** Initialize your data structure here. */ public RandomizedCollection() { nums = new ArrayList<Integer>(); locs = new HashMap<Integer, Set<Integer>>(); } /** Inserts a value to the collection. Returns true if the collection did not already contain the specified element. */ public boolean insert(int val) { boolean contain = locs.containsKey(val); if ( ! contain ) locs.put( val, new LinkedHashSet<Integer>() ); locs.get(val).add(nums.size()); nums.add(val); return ! contain ; } /** Removes a value from the collection. Returns true if the collection contained the specified element. */ public boolean remove(int val) { boolean contain = locs.containsKey(val); if ( ! contain ) return false; int loc = locs.get(val).iterator().next(); locs.get(val).remove(loc); if (loc < nums.size() - 1 ) { int lastone = nums.get( nums.size()-1 ); nums.set( loc , lastone ); locs.get(lastone).remove( nums.size()-1); locs.get(lastone).add(loc); } nums.remove(nums.size() - 1); if (locs.get(val).isEmpty()) locs.remove(val); return true; } /** Get a random element from the collection. */ public int getRandom() { return nums.get( rand.nextInt(nums.size()) ); }}
阅读全文
0 0
- leetcode 381. Insert Delete GetRandom O(1)
- leetcode 381. Insert Delete GetRandom O(1)
- [Leetcode] 381. Insert Delete GetRandom O(1)
- [leetcode]381. Insert Delete GetRandom O(1)
- leetcode 381. Insert Delete GetRandom O(1)
- 【leetcode】Insert Delete GetRandom O(1)
- 【Leetcode】Insert Delete GetRandom O(1)
- LeetCode[380] Insert Delete GetRandom O(1)
- Leetcode 之 Insert Delete GetRandom O(1)
- LeetCode:381 Insert Delete GetRandom O(1)
- leetcode之 Insert Delete GetRandom O(1)
- [leetcode] 380. Insert Delete GetRandom O(1)
- leetcode 380.Insert Delete GetRandom O(1)
- LeetCode Insert Delete GetRandom O(1)
- [LeetCode]380. Insert Delete GetRandom O(1)
- LeetCode 380---Insert Delete GetRandom O(1)
- 【Leetcode】380. Insert Delete GetRandom O(1)
- LeetCode 380. Insert Delete GetRandom O(1)
- 【原创】ARM串口控制台
- 【UOJ228】基础数据结构练习题(线段树)
- Web自动化之Headless Chrome测试框架集成
- 记一次失败的小米面试
- AsyncTask简单的用法 点击加载图片
- leetcode 381. Insert Delete GetRandom O(1)
- 【面经笔记】红黑树的特性与其在C++ STL中的应用
- hdu 5831 Rikka with Parenthesis II
- 队列
- splay_tree
- JAVA-1009. 说反话 (20)
- CentOS 镜像文件下载中各文件的区别
- fgm实例练习笔记-3.3点击累加数字,自加1
- OpenCV3 Python语言实现 笔记4