Ubuntu下学习栈和队列

本文介绍了在Ubuntu环境下如何学习和实现栈和队列这两种数据结构,包括顺序栈和链式栈的原理及代码实现,以及顺序队列和链式队列的创建和操作。同时,文章还提供了一个与栈和队列概念相关的题目——球钟问题,供读者实践和理解。
摘要由CSDN通过智能技术生成

Ubuntu下学习栈和队列

一、栈是什么?

栈(stack)又名堆栈,它是一种运算受限的线性表。限定仅在表尾进行插入和删除操作的线性表。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

栈原理

在这里插入图片描述

1、顺序栈

顺序表原理

栈是限制在一端进行插入操作和删除操作的线性表(俗称堆栈)
允许进行操作的一端称”栈顶“
另一固定端称为”栈底“
当栈中没有元素时称为空栈。特点:后进先出

实现顺序表

创建接口文件:sqstack.h
在这里插入图片描述
实现接口文件:sqstack.c
在这里插入图片描述
创建测试文件:test.c
在这里插入图片描述
执行结果
在这里插入图片描述

2、链式栈

链式栈原理

插入操作和删除操作均在链表头部进行,链表尾部就是栈底,栈顶指针就是头指针。
在这里插入图片描述
创建接口文件:linkstack.h
在这里插入图片描述
实现接口文件:linkstack.c
在这里插入图片描述
创建测试文件:test.c
在这里插入图片描述
执行结果
在这里插入图片描述

二、队列是什么?

队列是限制在两端进行插入操作和删除操作的线性表

  • 允许进行存入操作的一端称为“队尾”
  • 允许进行删除操作的一端称为“队头”
  • 当中队列没有元素时,称为“空队”
  • 特点:先进先出

1、顺序队列

在这里插入图片描述

双端队列

在这里插入图片描述

顺序队列实现

1、解决一个问题
入队->出队->入队->出队,进行循环
fron 指的是出队
rear 指的是入队
2、队列用数组进行队列排序

创建接口文件:sqquee.h

在这里插入图片描述

实现接口文件:sqquee.c

在这里插入图片描述

测试文件:test.c

在这里插入图片描述

2、链式队列

在这里插入图片描述

创建接口文件:linkqueue.h

在这里插入图片描述

实现接口文件:linkqueue.c

在这里插入图片描述

实现接口文件:test.c

在这里插入图片描述

执行结果

在这里插入图片描述

最后有个题目:球钟的问题?

想了解一下的,请找下面这个网站
https://www.cnblogs.com/shi-zhai/p/17127176.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值