一、什么是栈?
栈的概念及结构
栈:一种特殊的线性表,期允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的- -端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO (Last In First Out)的原则。
压栈:栈的插入操作叫做进栈/压栈入栈,入数据在栈顶。
出栈:栈的删除操作叫做出栈。出数据也在栈顶。
二、基本操作
栈
定义
初始化
初始化时,top给的是0,意味着top指向栈顶数据的下一个
初始化时,top给的是-1,意味着top指向栈顶数据
销毁
插入
删除
栈是否为空
取栈顶数据
队列
队列的概念:
用数组结构不太适合,出数据要挪动数据,队尾入,队头出,链表头删和找尾比较简单,所以用链式结构比较合适。
链表只需要头指针即可,此处我们需要头指针和尾指针。
队列定义
初始化和销毁
队列尾插
队列删除
注:free的不是指针b本身,而是指针指向的空间。
队列取头尾
队列大小
三、总结
栈和队列的共同点:
1.都是线性结构。
2.栈和队列的共同点是只允许在端点处插入和删除元素。
3.插入与删除的时间复杂度都是O(1),在空间复杂度上两者也一样。
栈和队列的区别:
1. 栈和队列的出入方式不同:栈是后进先出、队列是先进先出。
2. 删除数据元素的位置不同,栈的删除操作在表尾进行,队列的删除操作在表头进行。
最后,码字不易,如果觉得对你有帮助的话请点个赞吧,关注我,一起学习,一起进步!