欢迎来到天天文库
浏览记录
ID:55721687
大小:392.00 KB
页数:10页
时间:2020-06-01
《数据结构(c语言描述) 教学课件 作者 库波 第3章 栈和队列.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、数据结构(C#)主编:库波3.1栈3.2队列第3章栈和队列栈的定义及运算栈是限制在表的一端进行插入和删除的线性表。允许插入、删除的这一端称为栈顶,另一个固定端称为栈底。当表中没有元素时称为空栈。3.1栈栈的接口定义publicinterfaceIStack{intGetLength();//求栈的长度boolIsEmpty();//判断栈是否为空voidClear();//清空操作voidPush(Titem);//入栈操作TPop();//出栈操作TGetTop();//取栈顶元素}栈的存储和运算实现1、顺序栈用一片连续的存储空间来存储栈中的数据元素,这样的栈称为顺序栈(Sequenc
2、eStack)。类似于顺序表,用一维数组来存放顺序栈中的数据元素。栈顶指示器top设在数组下标为0的端,top随着插入和删除而变化,当栈为空时,top=-1。2.链栈栈的另外一种存储方式是链式存储,这样的栈称为链栈(LinkedStack)。链栈通常用单链表来表示,它的实现是单链表的简化。所以,链栈结点的结构与单链表结点的结构一样。由于链栈的操作只是在一端进行,为了操作方便,把栈顶设在链表的头部,并且不需要头结点。3.2队列队列的定义及其运算实际问题中还经常使用一种“先进先出”(FIFO---FirstInFirstOut)的数据结构:即插入在表一端进行,而删除在表的另一端进行,我们将这种数据
3、结构称为队或队列,把允许插入的一端叫队尾(rear),把允许删除的一端叫队头(front)。队列的存储和运算实现1、顺序队用一片连续的存储空间来存储队列中的数据元素,这样的队列称为顺序队列(SequenceQueue)。类似于顺序栈,用一维数组来存放顺序队列中的数据元素。队头位置设在数组下标为0的端,用front表示;队尾位置设在数组的另一端,用rear表示。front和rear随着插入和删除而变化。当队列为空时,front=rear=-1。2、链队队列的另外一种存储方式是链式存储,这样的队列称为链队列(LinkedQueue)。同链栈一样,链队列通常用单链表来表示,它的实现是单链表的简化。所
4、以,链队列的结点的结构与单链表一样。由于链队列的操作只是在一端进行,为了操作方便,把队头设在链表的头部,并且不需要头结点。栈的应用举例(括号匹配)队列的应用举例(回文判断)
此文档下载收益归作者所有