《零基础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)

}

相关推荐
没有故事的Zhang同学13 小时前
03-超级App软件平台@路由规则设计-【Universal-Links】与【App-Links详解】
程序员
没有故事的Zhang同学13 小时前
01-超级App软件平台@路由规则设计-【总纲】
程序员
没有故事的Zhang同学14 小时前
04-超级App软件平台@路由规则设计-【组件化路由框架详解】
程序员
没有故事的Zhang同学14 小时前
07-超级App软件平台@路由规则设计-【通用路由管理组件设计】
程序员
Gorway18 小时前
解析残差网络 (ResNet)
算法
没有故事的Zhang同学18 小时前
02-Debug调试@网络-Wireshark网络抓包工具:从原理到实践
程序员
拖拉斯旋风18 小时前
LeetCode 经典算法题解析:优先队列与广度优先搜索的巧妙应用
算法
Wect18 小时前
LeetCode 207. 课程表:两种解法(BFS+DFS)详细解析
前端·算法·typescript
SimonKing18 小时前
GitHub 10万星的OpenCode,正在悄悄改变我们的工作流
java·后端·程序员