GO语言队列(链表实现)

84 篇文章 3 订阅
该博客通过示例代码介绍了栈(先进后出,LIFO)和队列(先进先出,FIFO)两种数据结构的区别,并展示了在Go语言中如何使用链表实现栈的压入和弹出操作。在提供的代码中,定义了Student结构体作为链表节点,实现了push和pop方法。push方法用于将数组元素依次压入链表,pop方法则用于从链表头部移除并返回元素。
摘要由CSDN通过智能技术生成

栈与队列不同的是,栈是先进后出,队列是先进先出。所以在弹出元素时,有不同的地方

package main

import "fmt"

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

func push(student *Student, dis []int) bool {
	temp := student//设置临时指针
	for {
		if temp.Next != nil {//遍历当next不为空时,进行循环
			temp = temp.Next
		} else {
			break//一旦next为空则此节点为最后一个节点,退出循环
		}
	}
	for _, num := range dis {//遍历数组,将每一个数组的值加入节点
		node := Student{idnum: num, Next: nil}//由于next字段为下一个节点的地址,所以目前为空
		temp.Next = &node,将原链表的节点的next值换为当前创建的实例
		temp = &node//将临时地址换为此次创建的节点,进行循环
	}
	return true
}
func pop(student *Student) (bool, int, *Student) {
	if student == nil {//如果为空链表,则返回false
		return false, 0, student
	}
	temp := student.idnum//将第一个元素返回到临时变量
	student = student.Next//将首节点改变,改编为原链表的第二个节点
	return true, temp, student//进行返回,true ,元素值 ,和首节点
}
func main() {
	stu := Student{0, nil}
	push(&stu, []int{1, 2, 3, 4, 5, 6, 7, 8})
	ok, index, head := pop(&stu)
	if ok {
		fmt.Println("first node is ", index)
	}
	for head.Next != nil {//确定是否第一个元素弹出
		fmt.Println(head.idnum)
		head = head.Next
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值