详解Go语言中单链表的使用
作者:Hann?Yang 发布时间:2024-02-01 11:55:03
标签:Go,单链表
链表
一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点(链表中每一个元素称为结点)组成,结点可以在运行时动态生成。每个结点包括两个部分:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域。使用链表结构可以避免在使用数组时需要预先知道数据大小的缺点,链表结构可以充分利用计算机内存空间,实现灵活的内存动态管理。但是链表失去了数组随机读取的优点,同时链表由于增加了结点的指针域,空间开销比较大。
单链表结构
利用 struct 可以包容多种数据类型,结构体内也可以包含多个成员,这些成员可以是基本类型、自定义类型、数组类型,也可以是指针类型。这里可以使用指针类型成员来存放下一个结点的地址。如以下定义,成员 data 用来存放结点中的数据(整数类型),next 是指针类型的成员,它指向 ListNode struct 类型数据,也就是下一个结点的数据类型。
type ListNode struct {
data int
next *ListNode
}
创建节点
节点声明和赋值有以下几种格式:
package main
import "fmt"
type ListNode struct {
data int
next *ListNode
}
func main() {
var head *ListNode
head = new(ListNode)
head.data = 1
var node1 = new(ListNode)
node1.data = 2
var node2 = &ListNode{3, nil}
var node3 = &ListNode{data: 4}
fmt.Println(*head)
fmt.Println(*node1)
fmt.Println(*node2)
fmt.Println(*node3)
}
/* 输出:
{1 <nil>}
{2 <nil>}
{3 <nil>}
{4 <nil>}
*/
遍历链表
一个for循环即可,结构描述的链表没有空链表的,不论data是何种类型,一旦声明即使不马上赋值也会有类型默认值,比如new(ListNode)即赋值了ListNode{0, nil}。
func showNode(p *ListNode) {
fmt.Print(*p)
for p.next != nil {
p = p.next
fmt.Print("->", *p)
}
fmt.Println()
}
头插法
新结点放在链表的最前面
package main
import "fmt"
type ListNode struct {
data int
next *ListNode
}
func showNode(p *ListNode) {
fmt.Print(*p)
for p.next != nil {
p = p.next
fmt.Print("->", *p)
}
fmt.Println()
}
func main() {
var head = &ListNode{0, nil}
for i := 1; i < 5; i++ {
var node = ListNode{data: i}
node.next = head
head = &node
}
showNode(head)
}
/* 输出:
{4 0xc000084250}->{3 0xc000084240}->{2 0xc000084230}->{1 0xc000084220}->{0 <nil>}
*/
尾插法
新结点追加到链表的最后面
package main
import "fmt"
type ListNode struct {
data int
next *ListNode
}
func showNode(p *ListNode) {
fmt.Print(*p)
for p.next != nil {
p = p.next
fmt.Print("->", *p)
}
fmt.Println()
}
func main() {
var head, tail *ListNode
head = &ListNode{0, nil}
tail = head
for i := 1; i < 5; i++ {
var node = ListNode{data: i}
(*tail).next = &node
tail = &node
}
showNode(head)
}
/* 输出:
{0 0xc000084220}->{1 0xc000084230}->{2 0xc000084240}->{3 0xc000084250}->{4 <nil>}
*/
遍历方法
方法的定义:参数表放在函数名前
package main
import "fmt"
type ListNode struct {
data int
next *ListNode
}
func (p *ListNode) travel() {
fmt.Print(p.data)
for p.next != nil {
p = p.next
fmt.Print("->", p.data)
}
fmt.Println("<nil>")
}
func main() {
var head = &ListNode{0, nil}
head.travel()
for i := 1; i < 10; i++ {
var node = ListNode{data: i}
node.next = head
head = &node
}
head.travel()
var root *ListNode
root = new(ListNode)
root.travel()
}
/* 输出:
0<nil>
9->8->7->6->5->4->3->2->1->0<nil>
0<nil>
*/
链表长度
注意:函数与方法的区别
package main
import "fmt"
type ListNode struct {
data int
next *ListNode
}
func (head *ListNode) size() int {
size := 1
for head = head.next; head != nil; size++ {
head = head.next
}
return size
}
func Len(head *ListNode) int {
size := 1
for head = head.next; head != nil; size++ {
head = head.next
}
return size
}
func main() {
var head = &ListNode{0, nil}
fmt.Println(Len(head))
fmt.Println(head.size())
for i := 1; i < 10; i++ {
var node = ListNode{data: i}
node.next = head
head = &node
}
fmt.Println(Len(head))
fmt.Println(head.size())
}
/* 输出:
1
1
10
10
*/
链表转数组
package main
import (
"fmt"
)
type ListNode struct {
data int
next *ListNode
}
func (head *ListNode) size() int {
size := 1
for head = head.next; head != nil; size++ {
head = head.next
}
return size
}
func (head *ListNode) tolist() []int {
var res []int
res = make([]int, 0, head.size())
for head.next != nil {
res = append(res, head.data)
head = head.next
}
res = append(res, head.data)
return res
}
func (head *ListNode) tolist2() []int {
var res []int
res = make([]int, 0, head.size())
res = append(res, head.data)
head = head.next
for head != nil {
res = append(res, head.data)
head = head.next
}
return res
}
func main() {
var head = &ListNode{0, nil}
for i := 1; i < 10; i++ {
var node = ListNode{data: i}
node.next = head
head = &node
}
fmt.Println(head.tolist())
var root, tail *ListNode
root = &ListNode{0, nil}
tail = root
for i := 1; i < 10; i++ {
var node = ListNode{data: i}
(*tail).next = &node
tail = &node
}
fmt.Println(root.tolist2())
}
/* 输出:
[9 8 7 6 5 4 3 2 1 0]
[0 1 2 3 4 5 6 7 8 9]
*/
数组转链表
package main
import "fmt"
type ListNode struct {
data int
next *ListNode
}
func (p *ListNode) travel() {
fmt.Print(p.data)
for p.next != nil {
p = p.next
fmt.Print("->", p.data)
}
fmt.Println("<nil>")
}
func toNode(list []int) *ListNode {
var head, tail *ListNode
head = &ListNode{list[0], nil}
tail = head
for i := 1; i < len(list); i++ {
var node = ListNode{data: list[i]}
(*tail).next = &node
tail = &node
}
return head
}
func main() {
var lst = []int{1, 3, 2, 3, 5, 6, 6, 8, 9}
toNode(lst).travel()
}
/* 输出:
1->3->2->3->5->6->6->8->9<nil>
*/
来源:https://blog.csdn.net/boysoft2002/article/details/126442832


猜你喜欢
- 目录一、线程基础以及守护进程二、线程锁(互斥锁)三、线程锁(递归锁)四、死锁五、队列六、相关面试题七、判断数据是否安全八、进程池 &
- openlayer是目前我们gis常用的一款开源的,并且反馈都特别好的软件了,像之前的ol3, 风靡一时,地图实现也很简单,很实用,目前vu
- 实现效果通过源图片,在当前工作目录的/img目录下生成1000张,分别从1*1到1000*1000像素的图片。效果如下:目录结构实现示例#
- vue-loader和webpack项目配置及npm错误学习vue的同学都知道,想要生成一个vue项目,使用vue-cli脚手架工具直接生成
- 1.MySQL中并发和隔离控制机制Meta-data元数据锁:在table cache缓存里实现的,为DDL(Data Definition
- 项目使用Pyqt作为UI框架,使用相机线程捕捉image,并在QGraphicsView中显示,遇到以下问题:1、采集的数据为nparray
- 本文实例讲述了Python使用django获取用户IP地址的方法。分享给大家供大家参考。具体如下:函数实现:def get_client_i
- 这篇文章讨论了Python的from <module> import *和from <package> import
- 一般来说在 Python 中,为了解决内存泄漏问题,采用了对象引用计数,并基于引用计数实现自动垃圾回收。由于Python 有了自动垃圾回收功
- 一 卷积操作:在pytorch搭建起网络时,大家通常都使用已有的框架进行训练,在网络中使用最多就是卷积操作,最熟悉不过的就是torch.nn
- Anaconda 是一个旗舰版的python安装包, 因为普通的python没有库, 如果需要安装一些重要的库, 要经常一个一个下载,会非常
- 首先预览一下 PyCharm 在实际应用中的界面:(更改了PyCharm的默认风格)安装首先去下载最新的pycharm 2.7.3,进行安装
- 1.小猫运动游戏源码# @Author : 辣条'''多行注释本程序运行后会有一只小猫向前走安装模块 pip ins
- iframe标签在网页中可以创建一个内嵌框架,通过指定src属性来调用另一个网页文档的内容。和frameset一样,用它来对网页结构进行拆分
- 1、jieba库基本介绍(1)、jieba库概述jieba是优秀的中文分词第三方库- 中文文本需要通过分词获得单个的词语- jieba是优秀
- 你还没用 jQuery 写过导航菜单? 相信看到这些出色的jQuery导航菜单后,一定会为此而后悔没早点把 jQuery 应用到自己的Web
- /* 建立数据表 */ create table td_base_data( id int(10) not null auto_increm
- 概念django自带一套信号机制来帮助我们在框架的不同位置之间传递信息。也就是说,当某一事件发生时,信号系统可以允许一个或多个发送者(sen
- 我们在选择一件商品的时候,会先了解一些相关的商品信息,根据自己的需求和情况再进行选择。这种现象也同样适用于找工作,筛选一个岗位的重要环节,就
- 有2种方法:一、 QML中定义一个信号,连接Python里的函数;这里的函数不用特意指明为槽函数,普通函数即可。QML的信号连接Python