Leetcode 380. Insert Delete GetRandom O(1)

Design a data structure that supports all following operations in average O(1) time.

 

  1. insert(val): Inserts an item val to the set if not already present.
  2. remove(val): Removes an item val from the set if present.
  3. getRandom: Returns a random element from current set of elements. Each element must have the same probability of being returned.

Example:

// Init an empty set.
RandomizedSet randomSet = new RandomizedSet();

// Inserts 1 to the set. Returns true as 1 was inserted successfully.
randomSet.insert(1);

// Returns false as 2 does not exist in the set.
randomSet.remove(2);

// Inserts 2 to the set, returns true. Set now contains [1,2].
randomSet.insert(2);

// getRandom should return either 1 or 2 randomly.
randomSet.getRandom();

// Removes 1 from the set, returns true. Set now contains [2].
randomSet.remove(1);

// 2 was already in the set, so return false.
randomSet.insert(2);

// Since 2 is the only number in the set, getRandom always return 2.
randomSet.getRandom();

思路:利用randrange产生随机的ind,每个数被选到的概率相同。
 1 import random as rd
 2 
 3 class RandomizedSet(object):
 4 
 5     def __init__(self):
 6         """
 7         Initialize your data structure here.
 8         """
 9         self.numSet = set()
10         
11 
12     def insert(self, val):
13         """
14         Inserts a value to the set. Returns true if the set did not already contain the specified element.
15         :type val: int
16         :rtype: bool
17         """
18         if val not in self.numSet:
19             self.numSet.add(val)
20             return True
21         else:
22             return False
23         
24 
25     def remove(self, val):
26         """
27         Removes a value from the set. Returns true if the set contained the specified element.
28         :type val: int
29         :rtype: bool
30         """
31         if val in self.numSet:
32             self.numSet.remove(val)
33             return True
34         else:
35             return False
36         
37 
38     def getRandom(self):
39         """
40         Get a random element from the set.
41         :rtype: int
42         """
43         a = list(self.numSet)
44         ind = rd.randrange(0,len(a))
45         return a[ind]
46         
47         
48 
49 
50 # Your RandomizedSet object will be instantiated and called as such:
51 # obj = RandomizedSet()
52 # param_1 = obj.insert(val)
53 # param_2 = obj.remove(val)
54 # param_3 = obj.getRandom()

 

posted @ 2017-02-18 13:48  lettuan  阅读(165)  评论(0编辑  收藏  举报