- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
2 . 4 循 环 程 序 设 计 实 验
2.4.1 实验目的
1、掌握循环程序的设计方法。
2、掌握比较指令、转移指令和循环指令的使用方法。
3、进一步掌握调试工具的使用方法。
2.4.2 实验预习要求
1、复 习比较指令、条件转移指令和循环指令。
2、复 习循环程序的结构、循环控制方法等知识。
3、读 懂 “2.4.3 实验内容” 中给出的将十进制数转换为二进制数以及将二进制数转换为十进制数的程序。
4、根 据“ 2.4.3 实验内容”中给出的流程图和程序框架编写源程序,以便上机调试。
5、从 “2.4.4 实验习题”中任选一道题目,编写源程序,以便上机调试。
2.4.3 实验内容
计算 1+2+ …… n= ,其中 n 通过键盘输入。要求在屏幕上提供如下信息:
Please input a number(1 627): ;出现此信息后通过键盘输入一个小于 628 的无符号整数
1+2+ … ..n=sum ;其中 n 为用户输入的数, sum 为所求的累加和
程序运行情况如下图所示(说明:图中所运行程序允许累加和不大于一个 32 位二进制数所能表示
的范围)。
1、编 程指导
(1)
DATA
SEGMENT
INF1
DB Please input a
number (0-65535):$
IBUF
DB 7,0,6 DUP()
DATA ENDS
CODE SEGMENT
ASSUME CS: CODE, DS:DATA
START: MOV AX, DATA
MOV DS, AX
MOV DX, OFFSET INF1
MOV AH, 09H
INT 21H
MOV DX, OFFSET IBUF ;键入一个十进制数( 65535 )
MOV AH, 0AH
INT 21H
MOV CL, IBUF+1 ;十进制数的位数送 CX
MOV CH, 0
MOV SI, OFFSET IBUF+2 ;指向输入的第一个字符(最高位)
MOV AX, 0 ;开始将十进制数转换为二进制数
AGAIN: M OV DX, 10 ; ((0 10+a ) 10+ …) 10+a
4 0
MUL DX
AND BYTE PTR [SI], 0FH
ADD AL, [SI]
A DC AH, 0
I NC SI
LOOP AGAIN
MOV AH, 4CH
INT 21H
CODE ENDS
END START
本程序功能:从键盘接收一个无符号十进制整数(小于 65535),将其转换为二进制数,转换结果
存在 AX 寄存器中。
(2 )累加结果为一个 16 位的二进制数, 为了显示结果, 必需把它们转换为十进制数。 将二进制数转换
为十进制数的程序清单如下:
DATA SEGMENT
OBUF DB 6 DUP(
文档评论(0)