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

}

相关推荐
爱编程的鱼7 小时前
C# 变量详解:从基础概念到高级应用
java·算法·c#
HalvmånEver8 小时前
红黑树实现与原理剖析(上篇):核心规则与插入平衡逻辑
数据结构·c++·学习·算法·红黑树
刻意思考8 小时前
服务端和客户端之间接口耗时的差别
后端·程序员
哆啦刘小洋8 小时前
T:堆的基本介绍
算法
京东云开发者8 小时前
Hudi系列:Hudi核心概念之时间轴(TimeLine)
程序员
大模型教程9 小时前
万字详解让大模型写出好代码:上下文窗口的工程化实践
程序员·llm·agent
AresXue9 小时前
你是否也在寻找二进制和字符串的高效转换算法?
算法
大模型教程9 小时前
AI大模型从0到1:你的90天蜕变计划,告别小白直通前沿!
程序员·llm·agent
Swift社区9 小时前
从 0 到 1 构建一个完整的 AGUI 前端项目的流程在 ESP32 上运行
前端·算法·职场和发展
AI大模型9 小时前
RAG彻底爆了!一文读懂其架构演进及核心要点
程序员·llm·agent