- 1、本文档共21页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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
您可能关注的文档
- 初一上册数学有理数与其运算测试题(含答案).doc
- 刊头设计三年级.ppt
- 初一地理《埃与》PPT.ppt
- 国际金融青2章国际金融体系(经济06).ppt
- 商务英语阅读(第二版) 王关富 Unit5 Japan goes from dynamicto disheartened 课后答案.doc
- 初一语文《论语十二章》.ppt
- 初三政治第三次月考试卷与答题卡.doc
- 初三数学相似三角形答疑.ppt
- 矿大2009级二级词汇讲义.doc
- 初中一年级体育与健康必修1.ppt
- 2024年江西省寻乌县九上数学开学复习检测模拟试题【含答案】.doc
- 2024年江西省省宜春市袁州区数学九上开学学业水平测试模拟试题【含答案】.doc
- 《GB/T 44275.2-2024工业自动化系统与集成 开放技术字典及其在主数据中的应用 第2部分:术语》.pdf
- 中国国家标准 GB/T 44275.2-2024工业自动化系统与集成 开放技术字典及其在主数据中的应用 第2部分:术语.pdf
- GB/T 44285.1-2024卡及身份识别安全设备 通过移动设备进行身份管理的构件 第1部分:移动电子身份系统的通用系统架构.pdf
- 《GB/T 44285.1-2024卡及身份识别安全设备 通过移动设备进行身份管理的构件 第1部分:移动电子身份系统的通用系统架构》.pdf
- 中国国家标准 GB/T 44285.1-2024卡及身份识别安全设备 通过移动设备进行身份管理的构件 第1部分:移动电子身份系统的通用系统架构.pdf
- GB/T 44275.11-2024工业自动化系统与集成 开放技术字典及其在主数据中的应用 第11部分:术语制定指南.pdf
- 中国国家标准 GB/T 44275.11-2024工业自动化系统与集成 开放技术字典及其在主数据中的应用 第11部分:术语制定指南.pdf
- 《GB/T 44275.11-2024工业自动化系统与集成 开放技术字典及其在主数据中的应用 第11部分:术语制定指南》.pdf
文档评论(0)