汇编语言——子程序递归.ppt

  1. 1、本文档共21页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
汇编语言——子程序递归

*6.6 递归 使用递归法进行求解的问题需要具备以下几个条件: (1)原始问题可以分解成几个小问题,每个小问题的答案组合在一起可以得到原问题的解。 (2)分解出的每个小问题,要么可以简单解得,要么与原始问题是同一种类型,且比原问题稍简单。 (3)在经过有限次分解后,可以得到问题的最简单形式,而且最简形式的问题是可解的。 ; 递归与循环有一定的相似之处,都是同类问题的相似重复,重复操作在达到一定的条件后可以终止。重复正是计算机的主要特长。递归问题的分解次数称为递归的深度。要想让计算机完成递归问题的求解必须解决好这样几个问题:首先是用计算机语言描述出如何把问题分解,并且要让计算机记住分解出的是几个什么样的小问题;其次要告诉计算机对分解出的每个问题如何处理,充分简单的问题如何求解,同型问题如何重复;再就是要告诉计算机,当分解出的问题满足什么条件时不继续分解;最后还要能够让计算机把各个小问题的答案逐次组合成最终解。 ; 要让计算机记住当前已把问题解决到何种程度,就必须有相应的存储机制和存储空间。存储空间的多少往往在编写程序时并不知道,而是与需要求解的问题本身的大小有关;存储机制必须能够把较早期分解出的情况在组装答案时较晚取出,也就是“先进后出”。堆栈是各种存储结构中比较符合条件的一种,“先进后出”是栈操作的基本特征,而栈的总容量虽然必须在程序设计时确定,但可以根据计算机的性能设定为一个比较大的值。 无论是高级语言还是汇编语言,递归都是用带参数的子程序来实现的,其中的参数用来描述当前问题的复杂程度。递归则表现为在子程序的内部再调用它自身。 ; 递归子程序的基本模式是: 若参数满足问题的最简条件,则 直接求解答案,作为本次子程序调用的结果 否则 求解分解出的小问题中可直接求解者; 对小问题中的同型者,以较简单的参数调用自身; 把各个小问题的答案拼装,作为本次调用结果。 下面是Pascal语言的一个递归子程序,用于求n!。 FUNCTION fact(n:INTEGER):INTEGER; BEGIN IF n=1 THEN fact:=1 ELSE fact:=n*fact(n-1); END; ; 【例6.14】用汇编语言编写递归子程序,实现PASCAL子程序fact的功能。 【解】 ;================== fact ================= ; 功能 : 计算n! ; 入口 : 调用前把整数n入栈 ; 出口 : AX = n!的计算结果 ; 破坏寄存器 : 无 ;==========================================; fact PROC NEAR PUSH BP MOV BP,SP PUSH BX PUSH DX MOV BX,[BP+4] CMP BX,1 JG f1 ;参数n1转 MOV AX,1 ;最简情况,把返回结果放到AX中 JMP f2;f1: MOV DX,BX DEC DX ;计算n-1 PUSH DX ;把n-1入栈,准备递归调用 CALL fact ;递归调用,结果从AX带回 POP DX ;丢弃调用前入栈的参数 MUL BX ;AX*BX,在AX中的积作为拼装结果 f2: POP DX POP BX POP BP RET fact ENDP; 【例6.15】设例6.10和例6.11编写的子程序read和write已建立在子程序库中。在例6.14的子程序fact的基础上,编写完整程序,从键盘读入一个正整数,显示出它的阶乘值。 【解】 EXTRN read:FAR,wri

您可能关注的文档

文档评论(0)

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

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

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档