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

}

相关推荐
程序员鱼皮17 小时前
67个AI编程必会知识,1.6w字一次讲透!女友:“你要考研啊?!”
ai·程序员·编程·ai编程·vibe coding
炫饭第一名17 小时前
速通Canvas指北🦮——图形、文本与样式篇
前端·javascript·程序员
得物技术17 小时前
得物社区搜推公式融合调参框架-加乘树3.0实战
算法
Qinana18 小时前
150行代码搞定私有知识库!Node.js + LangChain 打造最小化 RAG 系统全流程
人工智能·程序员·node.js
一拳不是超人18 小时前
AI时代,35岁程序员焦虑终结:经验从负债变资产
人工智能·程序员
SimonKing18 小时前
觅得又一款轻量级数据库管理工具:GoNavi
java·后端·程序员
牛奶1 天前
系统的弃子与倦怠的灵魂:在液态社会中审视“修正主义”与职场异化
程序员·团队管理·午夜话题
舒一笑1 天前
如何获取最新的技术趋势和热门技术
人工智能·程序员
会员源码网2 天前
使用`mysql_*`废弃函数(PHP7+完全移除,导致代码无法运行)
后端·算法
木心月转码ing2 天前
Hot100-Day10-T438T438找到字符串中所有字母异位词
算法