导读:本期聚焦于小伙伴创作的《Go 中如何使用 container/list 传递链表并实现两数相加》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《Go 中如何使用 container/list 传递链表并实现两数相加》有用,将其分享出去将是对创作者最好的鼓励。

在Go语言的开发场景中,container/list包提供了官方实现的双向链表结构,支持灵活的节点增删改操作,常被用于需要动态存储有序数据的场景。两数相加是链表操作的经典问题,核心是将两个用链表表示的非负整数按位相加,处理进位后返回新的链表结果,下面我们一步步实现完整逻辑。

Go 中如何使用 container/list 传递链表并实现两数相加

container/list 基础用法

Go的container/list包中的List类型是一个双向链表,每个节点由Element类型表示,使用时需要先导入对应的包。以下是常用的操作示例:

package main

import (
	"container/list"
	"fmt"
)

func main() {
	// 创建新的链表
	l := list.New()
	// 向链表尾部添加元素
	l.PushBack(1)
	l.PushBack(2)
	l.PushBack(3)
	// 遍历链表元素
	for e := l.Front(); e != nil; e = e.Next() {
		fmt.Print(e.Value, " ")
	}
	// 输出结果:1 2 3
}

构建表示数字的链表

我们用链表的每个节点存储数字的一位,低位在前高位在后,比如数字342用链表表示为2->4->3。下面的函数可以将整数转换为对应的链表:

package main

import (
	"container/list"
)

// 将整数转换为链表,低位在前
func numToList(num int) *list.List {
	l := list.New()
	if num == 0 {
		l.PushBack(0)
		return l
	}
	for num > 0 {
		digit := num % 10
		l.PushBack(digit)
		num = num / 10
	}
	return l
}

实现两数相加逻辑

两数相加的核心逻辑是同时遍历两个链表,按位相加,记录进位值,将每一位的结果放入新的链表。完整的实现代码如下:

package main

import (
	"container/list"
	"fmt"
)

// 两数相加函数,接收两个链表,返回结果链表
func addTwoNumbers(l1 *list.List, l2 *list.List) *list.List {
	result := list.New()
	carry := 0 // 进位值
	e1 := l1.Front()
	e2 := l2.Front()
	// 遍历两个链表,直到都为空且没有进位
	for e1 != nil || e2 != nil || carry > 0 {
		sum := carry
		if e1 != nil {
			sum += e1.Value.(int)
			e1 = e1.Next()
		}
		if e2 != nil {
			sum += e2.Value.(int)
			e2 = e2.Next()
		}
		// 计算当前位的值和新的进位
		digit := sum % 10
		carry = sum / 10
		result.PushBack(digit)
	}
	return result
}

// 打印链表内容
func printList(l *list.List) {
	for e := l.Front(); e != nil; e = e.Next() {
		if e.Next() != nil {
			fmt.Print(e.Value, "->")
		} else {
			fmt.Print(e.Value)
		}
	}
	fmt.Println()
}

func main() {
	// 测试:342 + 465 = 807,对应链表2->4->3 + 5->6->4 = 7->0->8
	num1 := 342
	num2 := 465
	l1 := numToList(num1)
	l2 := numToList(num2)
	fmt.Print("第一个数字链表:")
	printList(l1)
	fmt.Print("第二个数字链表:")
	printList(l2)
	result := addTwoNumbers(l1, l2)
	fmt.Print("相加结果链表:")
	printList(result)
	// 验证结果:将结果链表转换为数字
	total := 0
	multi := 1
	for e := result.Front(); e != nil; e = e.Next() {
		total += e.Value.(int) * multi
		multi *= 10
	}
	fmt.Printf("相加结果对应的数字:%dn", total)
}

注意事项

  • container/list的Element的Value是interface{}类型,使用时需要进行类型断言,避免类型错误。
  • 传递链表时直接传递*list.List指针即可,不需要额外拷贝节点,Go的链表结构本身支持引用传递。
  • 处理进位时要考虑最后一位相加后仍有进位的情况,需要额外添加一个节点存储进位值。

container/listGo_链表两数相加链表操作修改时间:2026-06-10 15:21:25

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。