首页 > 其他分享 >golang 实现链表爽不爽?

golang 实现链表爽不爽?

时间:2023-02-27 22:55:48浏览次数:48  
标签:node golang nil 插法 list 链表 num 不爽

犹记得刚学 C 语言的时候,学到指针这一章,就会有让我们写链表的需求,头插法,尾插法,翻转链表,合并链表,约瑟夫环等等

学的不亦乐乎,但是 对于指针刚学的时候,真是摸不着脑壳,不知道 xdm 会有这种感受吗,动不动就段错误

今天,我们来看看 golang 写链表是有多爽

思路大概是这样的:

  • 这里我们简单写,就不写循环链表了
  • 需要一个链表结构体,这个结构体得有头指针,有尾指针
  • 需要一个节点的结构体,这个里面有节点的数据,节点的下一个指针
  • 我们这就来实现 头插法尾插法

定义数据结构

  • 定义链表结构
type MyList struct {
    head *ListNode
    tail *ListNode
}
  • 定义节点结构
type ListNode struct {
    num int
    next * ListNode
}

实现头插法

所谓链表,就像排队一样,队员和队员之间用线连起来,但是这个线是有一个明确方向的,头插法,就是从链表头插入元素,新元素成为头

func (list *MyList) HeadInsert(num int) {
	// 初始化一个节点,填入数据,和下一个指针指向 空
	node := &ListNode{
		num:  num,
		next: nil,
	}
	// 判断尾巴 和 头都是空,那么说明这一次是第 一个节点,头和尾都指向这个节点即可
	if list.tail == nil && list.head == nil {
		list.tail = node
		list.head = node
		return
	}
	// 头插,从头插入
	node.next = list.head
	list.head = node
}

实现尾插法

尾插法就是从链表尾巴插入元素,新元素成为尾巴

func (list *MyList) TailInsert(num int) {
	// 初始化一个节点,填入数据,和下一个指针指向 空
	node := &ListNode{
		num:  num,
		next: nil,
	}
	// 判断尾巴 和 头都是空,那么说明这一次是第 一个节点,头和尾都指向这个节点即可
	if list.tail == nil && list.head == nil {
		list.tail = node
		list.head = node
		return
	}

	// 尾插,从尾插入
	list.tail.next = node
	list.tail = node
}

看到上述写的尾插法和头插法是不是写法很类似,其实就是后面的几行代码逻辑不一样而已,原理都是一样的

go 里面无论是使用指针,还是使用结构体,都是使用 . ,而不像 C 里面使用 ->

遍历链表

遍历链表就非常简单了,一个一个打出来就可以了

func (list *MyList) PrintList() {
	if list == nil{
		fmt.Println("list is nil")
		return
	}

	tmp := list.head

	for tmp != nil{
		fmt.Println(tmp.num)
		tmp = tmp.next
	}
}

联合上述方法一起跑一遍

我们联合上述的代码,拼拼凑凑来实现我们的链表

  • (头插或者尾插)插入 10 个数据
  • 遍历一下链表
func main() {
	// 插入 10 个数
	l := MyList{}
	for i:=0;i<10;i++{
		l.HeadInsert(i)
	}

	l.PrintList()
}

看完的兄弟们是什么感受,有没有觉得使用 golang 写链表真的是非常简单的事情,当然链表的思想还是和 C 是一样一样的,只不过 用 golang 来实现真的太方便了

欢迎点赞,关注,收藏

朋友们,你的支持和鼓励,是我坚持分享,提高质量的动力

好了,本次就到这里

技术是开放的,我们的心态,更应是开放的。拥抱变化,向阳而生,努力向前行。

我是阿兵云原生,欢迎点赞关注收藏,下次见~

标签:node,golang,nil,插法,list,链表,num,不爽
From: https://www.cnblogs.com/xiaomotong/p/17162282.html

相关文章

  • golang入门(十五)断言
    前面的文章提到过,golang是一门强类型的语言。即数据在使用前必须明确标识所属的数据类型。为了让golang中的slice和map可以像Python中的list和dict一样可以存储任意数据。......
  • 力扣中19 删除链表的倒数第N个节点
     就是双指针移动呢忽略了特殊情况的判断有可能是设置的标记倒数第n个节点的指针还没移动呢形如例子【1,2  n=2】或者链表很短都不存loc下下个元素会找不到溢出......
  • 链表双指针技巧
    题目难度要点分隔链表●快慢指针:不用两个新链表拼接,使用原地修改合并K个升序链表●最小堆:类ProirityQueue的使用环形链表●快慢指针:相遇有环......
  • Go组件库总结之介入式链表
    本篇文章我们用Go封装一个介入式的双向链表,目的是将链表的实现和具体元素解耦。文章参考自:https://github.com/brewlin/net-protocol1.元素的接口typeElementinterface......
  • 彻底搞懂React-hook链表构建原理
    写在前面的小结每一个hook函数都有对应的hook对象保存状态信息useContext是唯一一个不需要添加到hook链表的hook函数只有useEffect、useLayoutEffect以及us......
  • 力扣简876 链表的中间节点
    只要一个一步一步走另一个指针两步两步走然后快的走到终点慢的就是中点//只有两种情况一种中间节点有一个一种有两个分开讨论一下publicstaticListNodemiddleNo......
  • [数据结构] 单链表
    一、C语言实现1.1结构体定义typedefintElementType;//定义一个链表结构体structListNode{ElementTypeval;structListNode*next;};1.2相关方法......
  • golang-标准库时间time
    packagemainimport("fmt""time")funcmain(){t:=time.Now()//time.Timetime.Date(2023,time.February,19,14,38,1,393023500,ti......
  • golang-标准库文件操作
    packagemainimport( "bufio" "fmt" "os" "strings")funcexample1(){ filename:="e:/test.txt"//内容为abc //Open是只读方式打开实际是调用的OpenFile......
  • golang基础知识查漏补缺(持续更新)
    表达式与语句简单来说,一个表达式表示一个值,而一条语句表示一个操作。但是在实际中,有些个表达式可能同时表示多个值,有些语句可能是由很多更基本的语句组成的。另外,根据场合......