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