GO语言栈(链表实现)

84 篇文章 3 订阅

栈,先进后出的规则

package main

import "fmt"

//Student is a test struct
type Student struct {
	base  *Student
	top   *Student
	idnum int
	Next  *Student
}

func push(head *Student, arr []int, top *Student) *Student { //向栈中添加新的元素
	for _, num := range arr {
		lstu := Student{idnum: num, Next: nil}
		top.Next = &lstu //将数组中的元素的地址放到上一个元素的next指针位置
		top = &lstu
	}
	return top //返回头节点,这里可以返回,可以不返回头节点,使用作为参数传进来的头节点也可以,在链表之后添加新的元素对头节点不影响,但是如果不返回头节点,需要在声明函数时,写无返回值
}
func pop(head *Student) (int, bool) { //从栈中弹出最后一个元素
	if head == nil { //判断是否为空链表
		return 0, false
	}
	p := head //设置临时指针,指向头节点
	for {
		if p.Next.Next == nil { //判断下一个节点的next值是否为空,如果为空
			num := p.Next.idnum //将下一个节点的idnum进行临时保存
			p.Next = nil        //改变此节点的next地址,改为空,在之后访问到此处,会停止循环
			return num, true    //取到最后的元素,则会返回元素,返回true
		}
		p = p.Next //如果不是最后一个节点,则进行下一个节点的遍历
	}
}
func main() {
	stu := Student{idnum: 0, Next: nil} //声明一结构体的对象,next值为nil
	stu.base = &stu
	stu.top = &stu
	push(&stu, []int{1, 2, 3, 4, 5, 6, 7}, stu.top) //将数组的元素放入链表中
	fmt.Println(pop(&stu))                          //使用pop弹出最后一个元素,并返回最后一个元素值
	p := &stu
	for { //遍历链表,将链表中的值输出,以确定是否将数组中的元素放入链表,并确定是否将链表的最后一个值弹出
		if p != nil {
			fmt.Println(p.idnum)
			p = p.Next
		} else {
			break
		}
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值