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

}

相关推荐
刀法如飞40 分钟前
AI时代,人人都是需求描述工程师
程序员·aigc·ai编程·需求文档
颜酱11 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
刀法如飞12 小时前
AI时代,程序员都应该是需求描述工程师
程序员·aigc·ai编程·需求文档
zone773917 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
ikunisback18 小时前
🦞 手把手教你用 OpenClaw 打造专属 AI 助手:从安装到自定义 Skills 全流程
程序员
ikunisback19 小时前
🦞 OpenClaw:2026年最火的开源AI Agent,一只"龙虾"凭什么拿下20万+ Star?
程序员
CoovallyAIHub19 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub19 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
陈随易20 小时前
刚上市就断货?如此火爆的编程显示器到底有什么魔力
前端·后端·程序员