原文地址:http://www.javashuo.com/article/p-zqgqvyxn-cr.html html
Design a data structure that supports all following operations in averageO(1) time. 數據結構
insert(val)
: Inserts an item val to the set if not already present.remove(val)
: Removes an item val from the set if present.getRandom
: Returns a random element from current set of elements. Each element must have the same probability of being returned. Example:app
// 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();
設計一個支持在平均 時間複雜度 O(1) 下,執行如下操做的數據結構。dom
insert(val)
:當元素 val 不存在時,向集合中插入該項。remove(val)
:元素 val 存在時,從集合中移除該項。getRandom
:隨機返回現有集合中的一項。每一個元素應該有相同的機率被返回。示例 :spa
// 初始化一個空的集合。 RandomizedSet randomSet = new RandomizedSet(); // 向集合中插入 1 。返回 true 表示 1 被成功地插入。 randomSet.insert(1); // 返回 false ,表示集合中不存在 2 。 randomSet.remove(2); // 向集合中插入 2 。返回 true 。集合如今包含 [1,2] 。 randomSet.insert(2); // getRandom 應隨機返回 1 或 2 。 randomSet.getRandom(); // 從集合中移除 1 ,返回 true 。集合如今包含 [2] 。 randomSet.remove(1); // 2 已在集合中,因此返回 false 。 randomSet.insert(2); // 因爲 2 是集合中惟一的數字,getRandom 老是返回 2 。 randomSet.getRandom();
260ms
1 class RandomizedSet { 2 var dic : [Int:Int] // value - key 3 var arr : [Int] //value 4 /** Initialize your data structure here. */ 5 init() { 6 arr = [Int]() 7 dic = [Int:Int]() 8 } 9 10 /** Inserts a value to the set. Returns true if the set did not already contain the specified element. */ 11 func insert(_ val: Int) -> Bool { 12 if dic[val] != nil { return false} 13 arr.append(val) 14 dic[val] = arr.count - 1 15 return true 16 } 17 18 /** Removes a value from the set. Returns true if the set contained the specified element. */ 19 func remove(_ val: Int) -> Bool { 20 if let preIndex = dic[val]{ 21 let lastIndex = arr.count - 1 22 dic[val] = nil 23 if lastIndex != preIndex { 24 dic[arr[lastIndex]] = preIndex 25 arr.swapAt(preIndex, lastIndex) 26 } 27 arr.removeLast() 28 }else{ 29 return false 30 } 31 return true 32 33 } 34 35 /** Get a random element from the set. */ 36 func getRandom() -> Int { 37 let i = Int.random(in: 0 ..< arr.count) 38 return arr[i] 39 } 40 } 41 42 /** 43 * Your RandomizedSet object will be instantiated and called as such: 44 * let obj = RandomizedSet() 45 * let ret_1: Bool = obj.insert(val) 46 * let ret_2: Bool = obj.remove(val) 47 * let ret_3: Int = obj.getRandom() 48 */
264ms設計
1 class RandomizedSet { 2 var nums:[Int] = [Int]() 3 var m:[Int:Int] = [Int:Int]() 4 5 /** Initialize your data structure here. */ 6 init() { 7 8 } 9 10 /** Inserts a value to the set. Returns true if the set did not already contain the specified element. */ 11 func insert(_ val: Int) -> Bool { 12 if m[val] != nil 13 { 14 return false 15 } 16 nums.append(val) 17 m[val] = nums.count - 1 18 return true 19 } 20 21 /** Removes a value from the set. Returns true if the set contained the specified element. */ 22 func remove(_ val: Int) -> Bool { 23 if m[val] == nil 24 { 25 return false 26 } 27 var last = nums.last! 28 m[last] = m[val] 29 nums[m[val]!] = last 30 nums.removeLast() 31 m[val] = nil 32 return true 33 } 34 35 /** Get a random element from the set. */ 36 func getRandom() -> Int { 37 return nums[Int.random(in: 0..<nums.count)] 38 } 39 } 40 41 /** 42 * Your RandomizedSet object will be instantiated and called as such: 43 * let obj = RandomizedSet() 44 * let ret_1: Bool = obj.insert(val) 45 * let ret_2: Bool = obj.remove(val) 46 * let ret_3: Int = obj.getRandom() 47 */ 48
312mscode
1 class RandomizedSet { 2 private var dict: [Int: Int] 3 private var array: [Int] 4 5 /** Initialize your data structure here. */ 6 init() { 7 self.dict = [Int: Int]() 8 self.array = [Int]() 9 } 10 11 /** Inserts a value to the set. Returns true if the set did not already contain the specified element. */ 12 func insert(_ val: Int) -> Bool { 13 if let _ = dict[val] { 14 return false 15 } else { 16 dict[val] = array.count 17 array.append(val) 18 return true 19 } 20 } 21 22 /** Removes a value from the set. Returns true if the set contained the specified element. */ 23 func remove(_ val: Int) -> Bool { 24 if let index = dict[val] { 25 if index == array.count - 1 { 26 array.removeLast() 27 } else { 28 let last = array.removeLast() 29 array[index] = last 30 dict[last] = index 31 } 32 dict[val] = nil 33 return true 34 } else { 35 return false 36 } 37 } 38 39 /** Get a random element from the set. */ 40 func getRandom() -> Int { 41 return array.count == 0 ? -1 : array[Int.random(in: 0..<array.count)] 42 } 43 } 44 45 /** 46 * Your RandomizedSet object will be instantiated and called as such: 47 * let obj = RandomizedSet() 48 * let ret_1: Bool = obj.insert(val) 49 * let ret_2: Bool = obj.remove(val) 50 * let ret_3: Int = obj.getRandom() 51 */