LeetCode: Linked List Random Node
Posted ying_vincent
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode: Linked List Random Node相关的知识,希望对你有一定的参考价值。
这题参照http://blog.jobbole.com/42550/
用的蓄水池算法,即更改ans的概率为1/(当前length)
1 /** 2 * Definition for singly-linked list. 3 * public class ListNode { 4 * int val; 5 * ListNode next; 6 * ListNode(int x) { val = x; } 7 * } 8 */ 9 public class Solution { 10 11 private ListNode head; 12 /** @param head The linked list‘s head. 13 Note that the head is guaranteed to be not null, so it contains at least one node. */ 14 public Solution(ListNode head) { 15 this.head = head; 16 } 17 18 /** Returns a random node‘s value. */ 19 public int getRandom() { 20 ListNode p = head; 21 int ans = p.val; 22 for (int i = 1; p.next != null; i++) { 23 p = p.next; 24 if ((int)(Math.random() * (i + 1)) == i) 25 ans = p.val; 26 } 27 return ans; 28 } 29 } 30 31 /** 32 * Your Solution object will be instantiated and called as such: 33 * Solution obj = new Solution(head); 34 * int param_1 = obj.getRandom(); 35 */
以上是关于LeetCode: Linked List Random Node的主要内容,如果未能解决你的问题,请参考以下文章
LeetCode2.Linked List — Linked List Cycle II 链表环2
[leetcode]Linked List-237. Delete Node in a Linked List
LeetCode27.Linked List—Reverse Linked List l链表逆置