第三章 栈的相关内容(常州大学).ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
3.1 栈 ( Stack ) 3.1.1 栈的定义及运算;只允许在一端插入和删除的顺序表 允许插入和删除 的一端称为栈顶 (top), 另一端称为栈底(bottom) 特点 后进先出 (LIFO);例:对于一个栈,给出输入项A、B、C,如果输入项序列由A B C组成,试给出所有可能的输出序列。;栈的顺序存储结构; 设s是SeqStack类型的指针变量。 s–data[0]是栈底元素 进栈时需将s–top加1,退栈时需将s–top 减1; 当栈满时再做进栈运算必定产生空间溢出,简称“上溢” 当栈空时再做退栈运算也将产生溢出,简称“下溢”。;进出栈示例;栈的基本操作;(1)InitStack(s) 初始化:初始化一个新的栈。 (2)StackEmpty(s) 栈空判断:若栈s空,则返回TRUE; (3)Push(s,x) 入栈:在栈s的顶部插入元素x,若栈满,则返回FALSE; (4)Pop(s) 出栈:若栈s不空,则返回栈顶元素,并从栈顶中删除该元素;否则,返回空元素NULL。 (5)GetTop(s,x) 取栈元素:若栈s不空,则返回栈顶元素;;void InitStack(SeqStack *s) {s-top=-1;} 置空栈 void ClearStack(SeqStack *s) { s-top=-1; };int Push(SeqStack *s,DataType x) { { s-top++; s-data[s-top]=x; } return 1; };DataType Pop(SeqStack *s) { DataType x { x= s-data[s-top]; s-top--; return(x); } };DataType GetTop(SeqStack *s, DataType x) { x= s-data[s-top]; return(x); };3.2 栈的应用举例 由于栈结构具有的后进先出的固有特性,致使栈成为程序设计中常用的工具。以下是几个栈应用的例子。 ;3.2.1 数制转换 十进制N和其它进制数的转换是计算机实现计算的基本问题,其解决方法很多。; n n div 8 n mod 8 1348 168 4 168 21 0 21 2 5 2 0 2 ;数制转换算法: void conversion( ) { InitStack(s); //建空栈 scanf(“%d”,x); //输入一个非负十进制整数 while(x!=0) { // x不等于零 循环 push(s, x% 8); // x/8第一个余数进栈 x=x/8; //整除运算 } while(! StackEmpty(s) ) { x=pop(s); printf(“%d”,x); //依次输出栈顶元素 } } ;3.2.4中缀表达式求值;算符优先关系表 表达式中任何相邻运算符c1、c2的优先关系有: c1c2:c1的优先级低于c2 c1=c2:c1的优先级等于c2 c1c2:c1的优先级高于c2;读出一个符号后,作如下处理: (1)是操作数: 将其压入操作数栈,读下一个符号。;(2)是运算符:;3)假如读出的是“)”,则: A)若运算符栈栈顶不是“(”,连续退出两操作数,退出一个运算符,作相应的运算,将结果压操作数栈,然后继续执行A B)若运算符栈栈顶为“(”,则消去括号,依次读下一个符号;?int express ( ) { //运算数栈,OP为运算符集合。 InitStack(OPTR); Push (OPTR, ‘# ‘); InitStack(OPND); c=getchar( );;续

文档评论(0)

糖糖 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档