- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* S3 §3.1 栈 第三章. 栈和队列 (Chapter 3. Stack and Queue) 栈(stack)是插入和删除操作受限的线性表,是一种后进先出(Last In First Out -- LIFO)的线性表。表头端称为栈底(bottom),表尾端称为栈顶(top),插入和删除都在栈顶进行。 bottom top S1 S2 S5 S6 S3 S4 S3 S3 S3 S3 S3 PUSH PUSH PUSH POP PUSH PUSH PUSH 栈的基本操作: INISTACK CLEAR GETTOP EMPTY PUSH POP 栈的实现: CONST maxlen = user_supply; TYPE stack = RECORD elem : ARRAY[1 .. maxlen] OF elemtype; top : 0 .. maxlen END; 顺序存储结构表示栈 FULL TYPE pointer = ↑ node; node = RECORD data : elemtype; next : pointer END; linkedstack = pointer; 链式存储结构表示栈----链栈(Linked_stack) 上溢(overflow):若栈的容量已全部用完,再进行插入操作(PUSH),就会发生上溢错误。 下溢(underflow):若栈已空,再进行删除操作(POP),就会发生下溢错误。 §3.2 栈的应用----表达式求值 任一表达式(expression)都是由操作数(operand)、操作符(operator)和界限符(delimiter)组成。 我们通常习惯使用中缀表达式(infix expression),但中缀表达式离不开括号(bracket)。若使用前缀表达式(prefix expression)或后缀表达式( postfix expression)则不需要括号。利用栈,可以将中缀表达式变为前缀表达式或后缀表达式,再用栈进行运算即可得到表达式的值(value)。 §3.3 栈与递归 递归(recursive):一个程序直接调用自己或通过其它程序调用自己就称为递归。根据调用关系可分为直接递归(direct recursive)和间接递归(indirect recursive )。 第 一 次 上 机 作 业 输入表达式字符串,以“=”表示结束, 计算并输出表达式值。 操作数可以是整数或实数,操作符有 “+”、“-”、“*”、“/”、“^”(乘方)和 “sin( )”(正弦)、“cos( )”(余弦)、“log( )”(对数)、“ln( )”(自然对数)等函数。 栈在程序的过程或函数调用中的作用: 过程一 过程二 过程三 过程四 断 点 三 断 点 一 断 点 二 断点一 断点二 断点三 stack 调用子程序 返回断点 程序执行 递归是程序设计中一种强有力的工具。下面三种情况可用递归解决: 1、有些数学函数是递归定义的,对其求解可用递归; 2、有些数据结构具有递归特性,对其操作可用递归; 3、有些问题的解决方法用递归描述,对其求解也可用递归。 例: 求阶乘(factorial): Fact(n) = 1 当 n = 0 n·Fact(n-1) 当 n 0 { FUNC Fact (n:integer); If n=0 Then Return (1) { 出口条件 } Else Return (n * Fact (n-1)) { 递归调用部分 } ENDF; 例: 河内塔(Hanoi Tower)问题求解: A B C A B C 如何解决这个问题呢?真伤脑筋啊! 题目要求:1、将 n 个盘子从 A 柱移到 B 柱,C 柱可用; 2、每次只能移动一个盘子;
您可能关注的文档
- 六年级班主任工作实践计划2018、9.doc
- 鲁教版高一化学必修二第一章原子结构和元素周期律《原子结构》(课件)26.pptx
- 四川渠县崇德实验学校2019年下学期八年级生物上册第五单元第一章第二节线形动物和环节动物集体备课教案设计.docx
- 初中数学学习情况分析.docx
- 农产品中农药残留检测的样品前处理培训课件.ppt
- 人教版九年级物理课件:14.1热机 .ppt
- 高中物理专题复习总结之运动学.docx
- 湖南中学二年级第2单元第1课第1节-化学:9.1《溶液的形成》.ppt
- 2019年秋冀教版八年级上册英语同步练习题:Lesson 13 I Love Autumn.docx
- 高中选考微专题精练26(二十六)地形对交通聚落分布的影响.docx
- 19期末职二语文酒店焊接考试试卷.docx
- 人教版高中历史必修一第一单元《古代中国的政 治制度》检测试题.docx
- 人教版高一语文上册必修一《文化常识》教案设计.docx
- 全国高中数学联赛模拟题(11).docx
- 人教(部编版)七年级历史 上册 第6课 动荡的春秋时期 教案设计.docx
- 关于书籍的一些发展史.docx
- 2019年秋冀教版八年级上册英语同步练习题:Lesson 29 Our Ambitions and Dreams.docx
- 2019秋语文人教版选修《中国古代诗歌散文欣赏》练习试题:第六单元第24课种树郭橐驼传-Word版含解析.doc
- 江苏南通天星湖中学2017-2018学年高二下学期期末考试数学(理)题目-.docx
- 专题四:遗传的分子基础.doc
最近下载
- 译林版英语五年级上册复习课件(语法知识含部分练习).ppt VIP
- Siemens西门子家电iQ300 滚筒洗衣机 9 kg 1200 转 分钟 WB24UMZ01W 使用 安装指南_2.pdf
- 子网掩码与子网的划分.ppt VIP
- 安徽多层商业建筑工程项目冬季施工方案.doc VIP
- 潜在失效模式及后果分析(DFMEA).xls VIP
- 矿建工程监理月报.doc VIP
- 手术患者深静脉血栓的预防.pptx VIP
- 最新国学《弟子规》ppt精品课件.pptx VIP
- 从村寺_祠堂看宗族对土族乡村社会_省略_制_基于景阳镇李氏土族的田野调查_张兴.pdf VIP
- 《金融经济学二十五讲》课后习题及答案.pdf VIP
原创力文档


文档评论(0)