- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
2.4 堆栈和队列 栈和队列是两种特殊的线性表,是操作受限的线性表,仅在表的一端进行插入或删除操作。 基本知识点: 理解栈和队列的定义、特点及与线性表的异同;掌握顺序栈和链栈的组织方法、栈满、栈空的判断及其描述; 本章知识体系结构 栈 2.4.1 栈(stack) 1.栈的定义和特点 定义:限定仅在表尾进行插入或删除操作的线性表,表尾—栈顶,表头—栈底,不含元素的栈称空栈 入栈(压栈):栈的插入操作 出栈(弹栈):删除操作 例1:假设数据1,2,3顺序入栈,入栈时可以随时出栈,问出栈序列有几种? 设一个栈的输入序列为1、2、3、4,则借助栈所得到的输出序列不可能是( )。 A. 1、2、3、4 B. 4、3、2、1 C. 1、3、4、2 D. 4、1、2、3 2.4.2顺序栈的表示和实现--栈的顺序存储结构 main( ) { int i=0,j,x; sqstack *s; initstack(s); for(;i5;i++) { scanf(“%d”,x); push(s,x); } j=getlen(s); printf(“%d”,j; print(s; } 2.4.3链栈的表示和实现--栈的链式存储结构 【举例1】将从键盘输入的字符序列逆置输出 比如,从键盘上输入:tset a si sihT;算法将输出:This is a test 下面我们给出解决这个问题的完整算法。 typedef char Elemtype; void ReverseRead( ) { STACK S; //定义一个栈结构S char ch; InitStack(S); //初始化栈 while ((ch=getchar())!=’\n’) //从键盘输入字符,直到输入换行符为止 Push(S ,ch); //将输入的每个字符入栈 while (!StackEmpty(S)) { //依次退栈并输出退出的字符 Pop(S,ch); putchar(ch); } putchar(‘\n’); } 【举例2】十进制数值转换成二进制 使用展转相除法将一个十进制数值转换成二进制数值。即用该十进制数值除以2,并保留其余数;重复此操作,直到该十进制数值为0为止。最后将所有的余数反向输出就是所对应的二进制数值。 比如:(692)10 = (1010110100)2,其展转相除的过程如图所示: 下面给出解决这个问题的完整算法。 void Decimal _ Binary ( ) { STACK S; //定义栈结构S InitStack(S); //初始化栈S scanf(“%d”,data); //输入十进制正整数 while (data) { Push(S,data%2); //余数入栈 data/=2; //被除数data整除以2,得到新的被除数 } while (!StackEmpty(S)) { //依次从栈中弹出每一个余数,并输出之 Pop(S,data); printf(“%d”,data); } } 【举例3】检验表达式中的括号匹配情况 假设在一个算术表达式中,可以包含三种括号:圆括号“(”和“)”,方括号“[”和“]”和花括号“{”和“}”,并且这三种括号可以按任意的次序嵌套使用。比如,...[...{...}...[...]...]...[...]...(...)..。现在需要设计一个算法,用来检验在输入的算术表达式中所使用括号的合法性。 算术表达式中各种括号的使用规则为:出现左括号,必有相应的右括号与之匹配,并且每对括号之间可以嵌套,但不能出现交叉情况。我们可以利用一个栈结构保存每个出现的左括号,当遇到右括号时,从栈中弹出左括号,检验匹配情况。在检验过程中,若遇到以下几种情况之一,就可以得出括号不匹配的结论。 (1)当遇到某一个右括号时,栈已
您可能关注的文档
最近下载
- 日立电梯UAX-Ⅱ图纸K3500429.pdf
- HP Prime快速入门手册.pdf VIP
- 汽车底盘系统检修(张振东)任务1 离合器踏板的检查与调整.ppt VIP
- 2025版北师大版数学二年级上册全册教学设计教案.pdf
- 汽车底盘系统检修(张振东)任务3 离合器分离轴承、压盘和从动盘的检修.ppt VIP
- 2023年人教版小升初语文模拟试卷含答案 .pdf VIP
- 慢性老年病患者日常用药误区及对策.doc VIP
- 人教版三年级上册数学全册教学设计(配2025年秋新版教材).docx
- 《人工环境工程学科奖学金2011预.doc VIP
- 初高中衔接课因式分解市公开课一等奖百校联赛获奖课件.pptx VIP
文档评论(0)