《数据结构》栈和队列A.pptVIP

  • 23
  • 0
  • 约5.42千字
  • 约 26页
  • 2021-12-03 发布于上海
  • 举报
数据结构课程的内容 第三章 栈和队列 3.1 栈(Stack) 问:堆栈是什么?它与一般线性表有什么不同? 例1:一个栈的输入序列是12345,若在入栈的过程中允许出栈,则栈的输出序列43512可能实现吗?12345的输出呢? 43512不可能实现,主要是其中的12顺序不能实现; 12345的输出可以实现,只需压入一个立即弹出一个即可。 例3(严题集3.1)一个栈的输入序列为123,若在入栈的过程中允许出栈,则可能得到的出栈序列是什么? 例4:计算机系2001年考研题(程序设计基础) 设依次进入一个栈的元素序列为c,a,b,d,则可得到出栈的元素序列是: A)a,b,c,d B)c,d,a,b C)b,c,d,a D)a,c,d,b 5、实现方式一 顺序栈示意图 表和栈的操作区别——对线性表 s= (a1 , a2 , …. , an-1 , an ) 入栈操作——例如用堆栈存放(A,B,C,D) (注意要遵循“后进先出” 原则) 出栈操作——例如从栈中取出‘B’ (注意要遵循“后进先出” 原则) 补充1: 若入栈动作使地址向高端增长,称为“向上生成”的栈; 若入栈动作使地址向低端增长,称为“向下生成”的栈; 对于向上生成的栈 入栈口诀:堆栈指针top先压后加(v[top++]=x); 出栈口诀:堆栈指针top先减后弹(y=v[--top]) 。 补充3:实现方式二 链栈 链栈示意图 链栈的入栈函数、出栈函数 (以头指针为栈顶,在头指针处插入或删除!) 公共说明部分: typedef struct snode{ SElemType data; struct snode *link; }NODE; NODE *st, *p; int m=sizeof(NODE); 问:为什么要设计堆栈?它有什么独特用途? 调用函数或子程序非它莫属; 递归运算的有力工具; 用于保护现场和恢复现场; 简化了程序设计的问题。 数制转换(十转N) ——P48 设计思路:用栈暂存低位值 例2:括号匹配的检验————P49 设计思路:用栈暂存左括号 例3 :表达式求值 —-————P52 设计思路:用栈暂存运算符 例4:汉诺仪(Hanoi)塔-——P55 设计思路:用栈实现递归调用 小结 栈:限定从一端插入和删除的线性表 栈顶top、栈底bottom、空栈 顺序栈,链式栈 操作/运算 初始化、进栈、退栈、判栈空 上堂课若干问题讨论 讨论:自测卷第七题第2小题 【严题集2.6②】已知L是无表头结点的单链表,且P结点既不是首元结点,也不是尾元结点,请写出在P结点后插入S结点的核心语句序列。 答:此题答案不唯一。 * 3.2 队列(Queue) 1. 定义 2. 逻辑结构 3. 存储结构 4. 运算规则 5. 实现方式 1. 定义 2. 逻辑结构 3. 存储结构 4. 运算规则 5. 实现方式 3.1 栈 答:堆栈是一种特殊的线性表,它只能在表的一端(即栈顶)进行插入和删除运算。 与一般线性表的区别:仅在于运算规则不同。 一般线性表 堆栈 逻辑结构:一对一 逻辑结构:一对一 存储结构:顺序表、链表 存储结构:顺序栈、链栈 运算规则:随机存取 运算规则:后进先出(LIFO) “进” =压入=PUSH(x) “出” =弹出=POP ( y ) 3.1 栈 只能在栈顶运算,且访问结点时依照后进先出(LIFO)或先进后出(FILO)的原则。 关键是编写入栈和出栈函数,具体实现依顺序栈或链栈的不同而不同。 基本操作有入栈、出栈、读栈顶元素值、建栈、或判断栈满、栈空等。 4. 运算规则 5. 实现方式 A A C B A B A top top top top top 低地址L 高地址M B C D 435612中到了12顺序不能实现; 135426可以实现。 例2:如果一个栈的输入序列为123456,能否得到435612和135426的出栈序列? 答: 答: 答: 可以通过穷举所有可能性来求解: ① 1入1出, 2入2出,3入3出, 即123; ② 1入1出, 2、3入3、2出, 即132

文档评论(0)

1亿VIP精品文档

相关文档