1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-27 02:30:28 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/O(1) 时间插入、删除和获取随机元素 [FortPu].html

47 lines
2.3 KiB
HTML
Raw Normal View History

2022-03-27 20:38:29 +08:00
<p>设计一个支持在<em>平均&nbsp;</em>时间复杂度 <strong>O(1)</strong>&nbsp;下,执行以下操作的数据结构:</p>
<ul>
<li><code>insert(val)</code>:当元素 <code>val</code> 不存在时返回 <code>true</code>&nbsp;,并向集合中插入该项,否则返回 <code>false</code></li>
<li><code>remove(val)</code>:当元素 <code>val</code> 存在时返回 <code>true</code>&nbsp;,并从集合中移除该项,否则返回 <code>false</code>&nbsp;</li>
<li><code>getRandom</code>:随机返回现有集合中的一项。每个元素应该有&nbsp;<strong>相同的概率&nbsp;</strong>被返回。</li>
</ul>
<p>&nbsp;</p>
<p><strong>示例 :</strong></p>
<pre>
<strong>输入: </strong>inputs = [&quot;RandomizedSet&quot;, &quot;insert&quot;, &quot;remove&quot;, &quot;insert&quot;, &quot;getRandom&quot;, &quot;remove&quot;, &quot;insert&quot;, &quot;getRandom&quot;]
[[], [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>&nbsp;</p>
<p><strong>提示:</strong><meta charset="UTF-8" /></p>
<ul>
<li><code>-2<sup>31</sup>&nbsp;&lt;= val &lt;= 2<sup>31</sup>&nbsp;- 1</code></li>
<li>最多进行<code> 2 * 10<sup>5</sup></code>&nbsp;<code>insert</code> <code>remove</code><code>getRandom</code> 方法调用</li>
<li>当调用&nbsp;<code>getRandom</code> 方法时,集合中至少有一个元素</li>
</ul>
<p>&nbsp;</p>
<p><meta charset="UTF-8" />注意:本题与主站 380&nbsp;题相同:<a href="https://leetcode-cn.com/problems/insert-delete-getrandom-o1/">https://leetcode-cn.com/problems/insert-delete-getrandom-o1/</a></p>