leetcode 381. Insert Delete GetRandom O(1)
来源:互联网 发布:php jsonp callback 编辑:程序博客网 时间:2024/06/01 07:18
待继续了解....
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)
- JavaScript基础笔记_17-07-10
- eclipse装插件
- LocalBroadcastManager机制分析
- 遇到多个构造器参数时要考虑用构建器
- ES5 Array
- leetcode 381. Insert Delete GetRandom O(1)
- POJ1149 PIGS
- vector的reallocation
- 15.Nginx 服务器的高级配置
- k-近邻
- CentOS_6.5下安装mysql_5.5.48
- maven常见错误
- magic squire幻方的学习——奇数阶幻方
- StarUML破解教程