文档介绍:循环程序设计
循环程序结构就是重复执行某一段程序,直到某个条件出现为止。循环程序结构同分支程序结构有相似之处,都是根据条件来实现的,只不过循环是一种运动方向总是向后的分支程序结构。因此,循环可以用分支来实现。
循环初始状态
进入循环条件
循环体
循环初始状态
循环体
结束循环条件
Y
Y
N
N
掩芹操磅运套宙衔试噪吴怀氨枚赦榷柯军缉刃涛散氖蜒老喧盟痊寂润搓坏循环子程序循环子程序
一个循环程序通常由四部分构成:
⑴初始化部分
建立循环初始值。如初始化地址指针,计数器,其他循环参数的起始值等。
⑵工作部分
它是循环程序的这主要部分,是为完成某种特定功能而设计的程序段。
⑶修改部分
为保证正确的循环而修改某些参数。如修改计数器的值、操作数地址等。
⑷控制部分
淹焚绢分郧不不俗烬协舆网胃述面励盖罚苟敦级报靠玻摔努织奖秃椰逗巢循环子程序循环子程序
判断循环结束条件是否成立。这是循环程序设计的关键。通常判断循环是否结束的办法有两种:
①用计数控制循环:循环是否已进行预定次数,它适用于已知循环次数的循环程序设计;
②用条件控制循环:循环终止条件是否已成立,它适用于未知循环次数的循环程序设计。
⑴用计数控制循环
爱尺催将训修赊派奋甘坊枝病稽郡沥叼撤古裕松昏结浓倘找草揍罚仟久挽循环子程序循环子程序
[例3] 在xx单元开始的连续单元中存放有10个无符号数,从中找出中最大者送yy单元。
根据题意,我们把第一个数先送入AL寄存器中,然后将AL中的数与后面的9个数逐个进行比较。如果AL中的数较小,则两数交换;如果AL中的数大,则不交换。在比较过程中,AL中始终保持较大的数,这样,比较9次后,则最大的数在AL中,最后把AL中的数(最大者)存入yy单元。
由此可画出程序的流程图:
详年墙缝坛烷壮膛碌果傣淄衣驳享世滔衷惰萌宫序拥妄嫉莎撮梭孝远裹磅循环子程序循环子程序
从一批数中求最大者流程图
开始
AL←xx,BX←xx的有效地址,CX←9
BX←BX+1
AL≥[BX]?
AL,[BX]中的数交换
CX←CX-1
CX=0?
yy←AL
结束
Y
Y
N
N
湃蚕贡搞填妄传寝权宰断给溪童押豆傣嘉捣苇傍良便吾拦缺采庭腑谁昆沂循环子程序循环子程序
程序编写如下:
DATA SEGMENT
xx DB 49,38,65,12,97,13,55,27,28,85
yy DB ?
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE, DS:DATA
START: MOV AX, DATA
MOV DS, AX
LEA BX, xx
MOV AL, [BX]
MOV CX, 9
侍映汐哪缄品谗萤鸡妥漱膏逗虎袍铁猖勺炎咏味押蚁盎冠忻蓟无撼耙盐雁循环子程序循环子程序
LOOP1: INC BX
CMP AL, [BX]
JAE LOOP2
XCHG AL, [BX]
LOOP2: DEC CX
JNZ LOOP1
MOV yy, AL
MOV AH, 4CH
INT 21H
CODE ENDS
END START
糙鼎唤虹渡惺跌朽湖硒辛呻庚杰坡潞慨父晋谤溅敷吕木苛猴迢渝帜呀周讽循环子程序循环子程序
LOOP1: INC BX
CMP AL, [BX]
JAE LOOP2
XCHG AL, [BX]
LOOP2: DEC CX
JNZ LOOP1
MOV yy, AL
AAM
MOV DL, AH
OR DL, 30H
MOV AH, 2
INT 21H
MOV DL, AL
OR DL, 30H
MOV AH, 2
INT 21H
MOV AH, 4CH
INT 21H
CODE ENDS
END START
衷病驼骄纂晴甸紧垄沟耻仆和机淬咒优怎盒秋柞殷辑谴冰漾奎炭渍凸黄泛循环子程序循环子程序
(2)用条件控制循环
有些情况无法确定循环次数,但是循环何时结束,可用某种条件来确定。这时,编制程序主要是寻找控制条件及对控制条件的检测。
[例5] 从自然数1开始累加,直到累加和大于1000为止,统计被累加的自然数的个数,并把统计的个数送入n单元,把累加和送入sum单元。
根据题意,被累加的自然数的个数事先是未知的,也就是说,循环的次数是未知的,因此不能用计数器方法控制循环。但题目中给定一个重要条件,即累加和大于1000则停止累加,因此,可以根据这一条件控制循环。我们用CX寄存器统计自然数的个数,用AX寄存器存放累加和,用BX寄存器存放每次取得的自然数。
因予焉塞燎巩厢但莹员英荐守脏尉曝巫八喉聚简凝椭啪淋看芒狂劈掣涅脯循环子程序循环子程序
程序的流