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×(1i+11)××(1n1)=i1×i+1i××nn1=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. 链表随机节点的主要内容,如果未能解决你的问题,请参考以下文章

[382]. 链表结点

LeetCode Algorithm 21. 合并两个有序链表

LeetCode Algorithm 1669. 合并两个链表

LeetCode Algorithm 剑指 Offer 24. 反转链表

LeetCode Algorithm 328. 奇偶链表

LeetCode Algorithm 328. 奇偶链表