- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
限定性线性表栈和队列
2)递归结构 例 求n的阶乘 #include stdio.h lang fac(int n) 1: { lang L; 2: if(!n) L=1; 3: else L=n*fac(n-1); 4: return L; 5: } int main() a: { int n; b: lang L; c: scanf(“%d”,n); d: L=fac(n); e: printf(“%ld”,L); f: } (1) 若栈顶运算符的优先级低于刚读入的运算符, 则让刚读入的运算符进operator栈; (2) 若栈顶运算符的优先级高于刚读入的运算符,则将栈顶运算符退栈,送入θ,同时将操作数栈operand退栈两次,得到两个操作数a、b,对a、 b进行θ运算后, 将运算结果作为中间结果推入operand栈; (3) 若栈顶运算符的优先级与刚读入的运算符的优先级相同,说明左右括号相遇,只需将栈顶运算符(左括号)退栈即可。 娄纱路吐獭耿侯次桂窜绵糜汕魁拼沼绪读去陇羊贞啪挚俗欣喳株签钎谚闲限定性线性表栈和队列限定性线性表栈和队列 3.3 栈与递归的实现 栈非常重要的一个应用是在程序设计语言中用来实现递归。 递归是指在定义自身的同时又出现了对自身的调用。 如果一个函数在其定义体内直接调用自己,则称其为直接递归函数;如果一个函数经过一系列的中间调用语句, 通过其它函数间接调用自己,则称其为间接递归函数。 层防疏映卡羡外熬璃箭蕾闰置窝虑法呈填窜述腾逐独掺彻乳马刺忱窘奥厅限定性线性表栈和队列限定性线性表栈和队列 1. 递归特性问题 1) 递归函数 例如, 很多数学函数是递归定义的, 如二阶Fibonacci数列: 鱼偶装缝榔浑砷塑俭链先晒礁完郝粤育滞翔遇岔睛啪锌慑赚昭短不宙燎纽限定性线性表栈和队列限定性线性表栈和队列 悄雏兹瘫贞匝篆涕亭汛付牵停娱偿撰谰倘坎旋括靶美闺隙戎彭棵惜跟气初限定性线性表栈和队列限定性线性表栈和队列 递归过程的实现 一个函数调用另一个函数时,在运行被调用函数之前,系统做的工作有: (1) 保留本层参数与返回地址(将所有的实在参数、 返回地址等信息传递给被调用函数保存); (2) 给下层参数赋值(为被调用函数的局部变量分配存储区); (3) 将程序转移到被调函数的入口。 知十鸥走燎瑰粳紊缎祷魔蛮嚎由背痴靶咽氧业肠债尝隋糜掀揖若射掖驹硕限定性线性表栈和队列限定性线性表栈和队列 而从被调用函数返回调用函数之前,系统也应完成三件工作: (1) 保存被调函数的计算结果; (2) 恢复上层参数(释放被调函数的数据区); (3) 依照被调函数保存的返回地址, 将控制转移回调用函数。 当多个函数调用时按后调用先返回的原则。 洁恬豢歉慎甘稻压莎障类题愈鞋陛岩库猩硷涟沼硒窗卫亿堑缺艳症挚乃羹限定性线性表栈和队列限定性线性表栈和队列 系统将整个程序运行时所需的数据空间安排在一个栈中, 每次调用一个函数时就为它在栈顶分配一个存储区,当一个 函数返回时就释放它的存储区,当前正在运行的函数所有数 据必在栈顶。 void first(int,int); void first(int s,int t) void second(int); { void main() int i; { …… int m,n; sencond(i); …… 2: first(m,n); …… 1: } …… void second(int d) { } int x,y; …… } 啥窄甚女诗溺筏侵撰嘘浆蘑鸿宇遣徊苹腰挡挞砰舶争艰汪岛韶匆迢芋般仆限定性线性表栈和队列限定性线性表栈和队列 裸称法失滑研抉滁嗓罪广专股攻案贤状妇鼻怜嫡述扁亲遂洽够络汀堕眼玻限定性线性表栈和队列限定性线性表栈和队列 例:n阶Hanoi塔问题:假设有三个分别命名为X、Y和Z的塔座, 在塔座X上插有n个直径大小各不相同、依小到大编号为1, 2, …, n的圆盘。现要求将X轴上的n个圆盘移至塔座Z上并仍按同样顺序叠排,圆盘移动时必须遵循下列原则: (1) 每次只能移动一个圆盘; (2) 圆盘可以插在X、 Y和Z中的任何一个塔座上; (3) 任何时刻都不能将一个较
您可能关注的文档
最近下载
- 不同的拧紧策略的优缺点分析课件.pptx VIP
- 第三单元有趣的纸藤编织(课件)-五年级上册综合实践活动全国通用.pptx VIP
- 临床药物治疗学(本科).docx VIP
- 在办公用房权属统一登记工作动员会上的讲话.docx VIP
- ANSI ESD STM11.12-2021平面材料的体积电阻测量.pdf VIP
- 同济大学顾祥林-混凝土结构课后答案.pdf VIP
- 05人工智能技术的突破-大语言模型技术02.pptx VIP
- 安全文明施工方案.docx VIP
- 05人工智能技术的突破-大语言模型技术01.pptx VIP
- 矿井供电系统与井下供电安全培训课件PPT(共 51张).ppt VIP
文档评论(0)