mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-25 17:50:26 +08:00
47 lines
2.3 KiB
HTML
47 lines
2.3 KiB
HTML
<p>设计一个支持在<em>平均 </em>时间复杂度 <strong>O(1)</strong> 下,执行以下操作的数据结构:</p>
|
||
|
||
<ul>
|
||
<li><code>insert(val)</code>:当元素 <code>val</code> 不存在时返回 <code>true</code> ,并向集合中插入该项,否则返回 <code>false</code> 。</li>
|
||
<li><code>remove(val)</code>:当元素 <code>val</code> 存在时返回 <code>true</code> ,并从集合中移除该项,否则返回 <code>false</code> 。</li>
|
||
<li><code>getRandom</code>:随机返回现有集合中的一项。每个元素应该有 <strong>相同的概率 </strong>被返回。</li>
|
||
</ul>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>示例 :</strong></p>
|
||
|
||
<pre>
|
||
<strong>输入: </strong>inputs = ["RandomizedSet", "insert", "remove", "insert", "getRandom", "remove", "insert", "getRandom"]
|
||
[[], [1], [2], [2], [], [1], [2], []]
|
||
<strong>输出: </strong>[null, true, false, true, 2, true, false, 2]
|
||
<strong>解释:
|
||
</strong>RandomizedSet randomSet = new RandomizedSet(); // 初始化一个空的集合
|
||
randomSet.insert(1); // 向集合中插入 1 , 返回 true 表示 1 被成功地插入
|
||
|
||
randomSet.remove(2); // 返回 false,表示集合中不存在 2
|
||
|
||
randomSet.insert(2); // 向集合中插入 2 返回 true ,集合现在包含 [1,2]
|
||
|
||
randomSet.getRandom(); // getRandom 应随机返回 1 或 2
|
||
|
||
randomSet.remove(1); // 从集合中移除 1 返回 true 。集合现在包含 [2]
|
||
|
||
randomSet.insert(2); // 2 已在集合中,所以返回 false
|
||
|
||
randomSet.getRandom(); // 由于 2 是集合中唯一的数字,getRandom 总是返回 2
|
||
</pre>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>提示:</strong><meta charset="UTF-8" /></p>
|
||
|
||
<ul>
|
||
<li><code>-2<sup>31</sup> <= val <= 2<sup>31</sup> - 1</code></li>
|
||
<li>最多进行<code> 2 * 10<sup>5</sup></code> 次 <code>insert</code> , <code>remove</code> 和 <code>getRandom</code> 方法调用</li>
|
||
<li>当调用 <code>getRandom</code> 方法时,集合中至少有一个元素</li>
|
||
</ul>
|
||
|
||
<p> </p>
|
||
|
||
<p><meta charset="UTF-8" />注意:本题与主站 380 题相同:<a href="https://leetcode-cn.com/problems/insert-delete-getrandom-o1/">https://leetcode-cn.com/problems/insert-delete-getrandom-o1/</a></p>
|