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

}

相关推荐
得一录8 分钟前
星图·全参数调试qwen3.1-B
深度学习·算法·aigc
yyjtx9 分钟前
DHU上机打卡D22
算法
plus4s10 分钟前
2月14日(76-78题)
c++·算法·图论
pzx_00117 分钟前
【论文阅读】Attention Is All You Need
论文阅读·算法
-To be number.wan20 分钟前
算法学习日记 |贪心算法
c++·学习·算法·贪心算法
清钟沁桐33 分钟前
算法实现
算法
梦游钓鱼35 分钟前
c++中一维数组和二维数组的应用
数据结构·c++·算法
铁甲前沿35 分钟前
基于最小二乘拟合减小四轮定位数据采集误差的方法
算法
程序员酥皮蛋1 小时前
hot 100 第二十六题 26.环形链表 II
算法
啊阿狸不会拉杆1 小时前
《机器学习导论》第 16 章-贝叶斯估计
人工智能·python·算法·机器学习·ai·参数估计·贝叶斯估计