LeetCode Algorithm 382. 链表随机节点
Posted Alex_996
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode Algorithm 382. 链表随机节点相关的知识,希望对你有一定的参考价值。
题目链接:382. 链表随机节点
Ideas
算法:水塘抽样
数据结构:链表
思路:从链表头开始,遍历整个链表,对遍历到的第 i 个节点,随机选择区间 [0,i) 内的一个整数,如果其等于 0,则将答案置为该节点值,否则答案不变。
水塘抽样算法证明:
P
(
第
i
个
节
点
的
值
成
为
最
后
被
返
回
的
值
)
=
P
(
第
i
次
随
机
选
择
的
值
=
0
)
×
P
(
第
i
+
1
次
随
机
选
择
的
值
≠
0
)
×
⋯
×
P
(
第
n
次
随
机
选
择
的
值
≠
0
)
=
1
i
×
(
1
−
1
i
+
1
)
×
⋯
×
(
1
−
1
n
)
=
1
i
×
i
i
+
1
×
⋯
×
n
−
1
n
=
1
n
\\beginarrayl P( 第 i 个节点的值成为最后被返回的值) \\\\ =P( 第 i 次随机选择的值 =0) \\times P( 第 i+1 次随机选择的值 \\neq 0) \\times \\cdots \\times P( 第 n 次随机选择的值 \\neq 0) \\\\ =\\frac1i \\times\\left(1-\\frac1i+1\\right) \\times \\cdots \\times\\left(1-\\frac1n\\right) \\\\ =\\frac1i \\times \\fracii+1 \\times \\cdots \\times \\fracn-1n \\\\ =\\frac1n \\endarray
P(第i个节点的值成为最后被返回的值)=P(第i次随机选择的值=0)×P(第i+1次随机选择的值=0)×⋯×P(第n次随机选择的值=0)=i1×(1−i+11)×⋯×(1−n1)=i1×i+1i×⋯×nn−1=n1
Code
C++
class Solution
ListNode *head;
public:
Solution(ListNode* head)
this->head = head;
int getRandom()
int i = 1, ans = 0;
for (auto node = head; node; node = node->next)
if (rand() % i == 0)
ans = node->val;
++i;
return ans;
;
以上是关于LeetCode Algorithm 382. 链表随机节点的主要内容,如果未能解决你的问题,请参考以下文章
LeetCode Algorithm 21. 合并两个有序链表
LeetCode Algorithm 1669. 合并两个链表