自学内容网 自学内容网

《零基础Go语言算法实战》【题目 4-6】随机选择单链表的一个节点并返回

《零基础Go语言算法实战》

【题目 4-6】随机选择单链表的一个节点并返回

给定一个单链表,请随机选择链表的一个节点,并返回相应的节点值。保证每个节点被

选择的概率相同。

【解答】

① 思路。

通过 rand.Float64() 函数可以返回 [0,1) 范围内的随机数,利用这个函数完成随机化选择

节点的过程。

② Go 语言实现。

package main

import (

 "fmt"

 "math/rand"

)

// 定义单链表

type ListNode struct {

 Data int

 Next *ListNode

}

type Head struct {

 head *ListNode

}

// 初始化链表

func NewListNode(head *ListNode) Head {

 return Head{head: head}

}

// 返回随机节点的值

func (h *Head) GetRandom() int {

 scope, selectPoint, curr := 1, 0, h.head

 for curr != nil {

 if rand.Float64() < 1.0/float64(scope) {

 selectPoint = curr.Data

 }

 scope += 1

 curr = curr.Next

 }

 return selectPoint

}

func main() {

 nodeList := ListNode{6, nil}

 head := NewListNode(&nodeList)

 obj := NewListNode(head.head)

 ret := obj.GetRandom()

 fmt.Println(ret)

}


原文地址:https://blog.csdn.net/qq_39728668/article/details/145152492

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!