推荐文章:清华大学计算机考试数据结构与程 推荐文章简介: 试题内容:一、试给出下列有关并查集(mfsets)的操作序列的运算结果:union(1,2) , union(3,4) , union(3,5) , union(1,7) , union(3,6) , union(8,9) , union(1,8) , union(3,10) , union(3,11) , union(3,12) , unio
第五十一题:
一、请编制程序,其功能是:内存中连续存放着16个12位二进制数DB11DB10…DB0,每个二进制数均用两个字节表示,其存放格式均为
DB11 DB10 DB9 DB8 DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0
|←--------低地址字节-------→∣ |←----高地址字节----→∣
请按序将每个12位二进制数转换成以下格式
DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 DB11 DB10 DB9 DB8
|←------低地址字节-------→∣ |←-----高地址字节----→∣
转换结果按原序存放在内存中。
例如:
内存中有: 12H,30H,04H,50H,61H,00H…
结果为: 0123H,0045H,0610H…
部分程序已给出, 其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从RESULT开始存放,由过程SAVE保存到文件OUTPUT1.DAT中。
填空BEGIN和END之间已给出的一段源程序使其完整(空白已用横线标出,每行空白一般只需一条指令, 但采用功能相当的多条指令亦可),或删除BEGIN和END之间原有的代码并自行编程来完成要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生PROG1.EXE执行文件,最终运行程序产生结果(无结果或结果不正确者均不得分)。调试中若发现整个程序中存在错误之处, 请加以修改。
试题程序:
EXTRN LOAD:FAR,SAVE:FAR
N EQU 16
STAC SEGMENT STACK
DB 128 DUP(?)
STAC ENDS
DATA SEGMENT
SOURCE DB N*2 DUP(?)
RESULT DW N DUP(0)
NAME0 DB 'INPUT1.DAT',0
NAME1 DB 'OUTPUT1.DAT',0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
LEA DX,SOURCE ;数据区起始地址
LEA SI,NAME0 ;原始数据文件名
MOV CX,N*2 ;字节数
CALL LOAD ;从'INPUT1.DAT'中读取数据
;****BEGIN****
MOV BX,0
MOV DI,OFFSET RESULT
MOV CH,N
MOV CL,___________________
PRO: MOV AX,___________________
MOV DX,AX
SHR DL,____________________ ;12位无符号二进制数高八位右移
SHR AH,____________________ ;12位无符号二进制数低四位右移
SHL AL,____________________ ;12位无符号二进制数高八位左移
OR _______________________ ;新格式12位无符号二进制数低八位
MOV AL,AH
MOV AH,DL ;新格式12位无符号二进制数高四位
MOV BYTE PTR [DI],_________
MOV BYTE PTR [DI+1],_______
ADD DI,2
ADD BX,2
DEC CH
JNZ PRO
;****END****
LEA DX,RESULT ;结果数据区首址
LEA SI,NAME1 ;结果文件名
MOV CX,N*2 ;字节数
CALL SAVE ;保存结果到文件
RET
START ENDP
CODE ENDS
END START
第五十二题:
一、请编制程序,其功能是:内存中连续存放着10个无符号16位二进制数,现采用近似计算法求此10年数的近似平方根,其方法为:令某个数X依次减去1、3、5、7、9…等奇数,一直减到差值刚刚小于等于零为止,计算出所作的减法次数Y,即为该数X的近似平方根。得到的结果存入内存。
例如:
内存中有 0100H,0200H…
结果为 0010H,0016H…
部分程序已给出, 其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从RESULT开始存放,由过程SAVE保存到文件OUTPUT1.DAT中。
填空BEGIN和END之间已给出的一段源程序使其完整(空白已用横线标出,每行空白一般只需一条指令, 但采用功能相当的多条指令亦可),或删除BEGIN和END之间原有的代码并自行编程来完成要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生PROG1.EXE执行文件,最终运行程序产生结果(无结果或结果不正确者均不得分)。调试中若发现整个程序中存在错误之处, 请加以修改。
试题程序:
EXTRN LOAD:FAR,SAVE:FAR
N EQU 10
STAC SEGMENT STACK
DB 128 DUP(?)
STAC ENDS
DATA SEGMENT
SOURCE DB N DUP(?) ;顺序存放10个字节数
RESULT DB N DUP(0) ;存放结果
NAME0 DB 'INPUT1.DAT',0
NAME1 DB 'OUTPUT1.DAT',0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
LEA DX,SOURCE ;数据区起始地址
LEA SI,NAME0 ;原始数据文件名
MOV CX,N*2 ;字节数
CALL LOAD ;从'INPUT1.DAT'中读取数据
;****BEGIN****
LEA DI,RESULT
LEA SI,SOURCE
MOV CX,N
AGN0: MOV AX,[SI]
MOV BX,0
AGN1: __________________________
SUB AX,BX
________ STORE0
__________________________
JMP AGN1
STORE0: INC BX
__________________________
MOV [DI],BX
INC DI
__________________________
INC SI
__________________________
LOOP AGN0
;****END****
LEA DX,RESULT ;结果数据区首址
LEA SI,NAME1 ;结果文件名
MOV CX,N*2 ;字节数
CALL SAVE ;保存结果到文件
RET
START ENDP
CODE ENDS
END START
第五十三题:
一、请编制程序,其功能是:内存中连续存放着10个无序8位有符号二进制数,此十个数中正数和负数各为五个,现按就近原则将该10个数排列成负数和正数相同的序列(第一个数为负数)。
例如:
内存中有 81H,88H,A3H,03H,47H,E2H,76H,D8H,13H,50H
结果为 81H,03H,88H,47H,A3H,76H,E2H,13H,D8H,50H
部分程序已给出, 其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从RESULT开始存放,由过程SAVE保存到文件OUTPUT1.DAT中。
填空BEGIN和END之间已给出的源程序使其完整(空白已用横线标出,每行空白一般只需一条指令, 但采用功能相当的多条指令亦可),或删除BEGIN和END之间原有的代码并自行编程来完成要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生PROG1.EXE执行文件,最终运行程序产生结果(无结果或结果不正确者均不得分)。调试中若发现整个程序中存在错误之处, 请加以修改。
试题程序:
EXTRN LOAD:FAR,SAVE:FAR
N EQU 10
STAC SEGMENT STACK
DB 128 DUP(?)
STAC ENDS
DATA SEGMENT
SOURCE DB N DUP(?) ;顺序存放10个字节数
RESULT DB N DUP(0) ;存放结果
NAME0 DB 'INPUT1.DAT',0
NAME1 DB 'OUTPUT1.DAT',0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
LEA DX,SOURCE ;数据区起始地址
LEA SI,NAME0 ;原始数据文件名
MOV CX,N ;字节数
CALL LOAD ;从'INPUT1.DAT'中读取数据
;****BEGIN****
LEA DI,RESULT
MOV BL,___________
MOV CX,10
AGN0: MOV DX,CX
LEA SI,SOURCE
AGN1: MOV AL,[SI]
DEC DX
PUSH AX
AND AL,80H
CMP _________,________
JE STORE1
POP AX
INC SI
JMP AGN1
STORE1: POP AX
MOV [DI],AL
INC DI
ADD ________,80H
ARRY: CMP DX,0
JZ NEXT
INC SI
MOV AL,[SI]
________ SI
MOV [SI],AL
INC SI
DEC DX
JMP ARRY
NEXT: LOOP AGN0
;****END****
LEA DX,RESULT ;结果数据区首址
LEA SI,NAME1 ;结果文件名
MOV CX,N ;结果字节数
CALL SAVE ;保存结果到文件
RET
START ENDP
CODE ENDS
END START
第五十四题:
一、请编制程序,其功能是:内存中两个由7个ASCII字符组成的字符串进行如下操作:在原字符串之前加上字符#(23H);在原字符串之后加上字符*(2AH)及另外两个ASCII字符,这两个ASCII字符为原字符串中各字符(但不包括字符#和*)异或操作后的ASCII码(异或操作结果的高4位的ASCII码在前,低4位的ASCII码在后);最后加上回车符(0DH)及换行符(0AH)。
例如:
内存中有 46H,41H,30H,2EH,34H,3DH,31H(第一个ASCII字符串)
46H,41H,30H,2EH,34H,3DH,30H(第一个ASCII字符串)
结果为 23H(‘#’),46H,41H,30H,2EH,34H,3DH,31H,2AH(‘*’),
32H,31H,0DH,0AH,23H,46H,41H,30H,2EH,34H,3DH,
30H,2AH,32H,30H,0DH,0AH
部分程序已给出, 其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从RESULT开始存放,由过程SAVE保存到文件OUTPUT1.DAT中。
填空BEGIN和END之间已给出的源程序使其完整(空白已用横线标出,每行空白一般只需一条指令, 但采用功能相当的多条指令亦可),或删除BEGIN和END之间原有的代码并自行编程来完成要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生PROG1.EXE执行文件,最终运行程序产生结果(无结果或结果不正确者均不得分)。调试中若发现整个程序中存在错误之处, 请加以修改。
试题程序:
EXTRN LOAD:FAR,SAVE:FAR
N EQU 14
STAC SEGMENT STACK
DB 128 DUP(?)
STAC ENDS
DATA SEGMENT
SOURCE DB N DUP(?)
RESULT DB N+12 DUP(0)
NAME0 DB 'INPUT1.DAT',0
NAME1 DB 'OUTPUT1.DAT',0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
LEA DX,SOURCE ;数据区起始地址
LEA SI,NAME0 ;原始数据文件名
MOV CX,N ;字节数
CALL LOAD ;从'INPUT1.DAT'中读取数据
;****BEGIN****
LEA SI,0
LEA DI,0
MOV BX,2 ;两个ASCII字符串
REPEAT: MOV CX,7 ;第个字符串由7个ASCII字符组成
MOV AL,______________
MOV RESULT[DI],AL
INC DI
MOV AH,______________
CHAR: MOV AL,SOURCE[SI]
MOV RESULT[DI],AL
INC DI
INC SI
XOR AH,AL
LOOP _________________
MOV AL,______________
MOV RESULT[DI],AL
INC DI
MOV DH,2
MOV DL,AH ;异或结果暂存在DL中
MOV CL,4 ;先将异或结果高4位转换成ASCII字符
SHR AH,CL
CHANGE: CMP AH,10 ;本行开始的4行语句将一个十六进制数转换为ASCII码
JL ADD_0
ADD AH,’A’-’0’-10
ADD_0: ADD AH,’0’
MOV RESULT[DI],AH
INC DI
DEC DH
JZ EXT
MOV AH,DL
AND AH,0FH
JMP CHANGE
EXT: MOV AL,______________
MOV RESULT[DI],AL
INC DI
MOV AL,______________
MOV RESULT[DI],AL
INC DI
DEC BX
JZ _________________
JMP REPEAT
EXIT: NOP
;****END****
LEA DX,RESULT ;结果数据区首址
LEA SI,NAME1 ;结果文件名
MOV CX,N+12 ;结果字节数
CALL SAVE ;保存结果到文件
RET
START ENDP
CODE ENDS
END START
第五十五题:
一、请编制程序,其功能是:内存中连续存放着两个无符号字节数序列AK和BK(k=0,…,9),求序列CK,CK=AK―BK(CK以有符号字的形式按C0,…,C9的顺序连续存放)。
例如:
序列AK为 30H,FFH,80H,FFH…
序列BK为 00H,FFH,FFH,0AH…
则结果CK为 0030H,0000H,FF81H,FFF5H…
部分程序已给出, 其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从RESULT开始存放,由过程SAVE保存到文件OUTPUT1.DAT中。
填空BEGIN和END之间已给出的一段源程序使其完整(空白已用横线标出,每行空白一般只需一条指令, 但采用功能相当的多条指令亦可),或删除BEGIN和END之间原有的代码并自行编程来完成要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生PROG1.EXE执行文件,最终运行程序产生结果(无结果或结果不正确者均不得分)。调试中若发现整个程序中存在错误之处, 请加以修改。
试题程序:
EXTRN LOAD:FAR,SAVE:FAR
N EQU 10
STAC SEGMENT STACK
DB 128 DUP(?)
STAC ENDS
DATA SEGMENT
SOURCE DB N*2 DUP(?)
RESULT DB N DUP(0)
NAME0 DB 'INPUT1.DAT',0
NAME1 DB 'OUTPUT1.DAT',0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
LEA DX,SOURCE ;数据区起始地址
LEA SI,NAME0 ;原始数据文件名
MOV CX,N*2 ;字节数
CALL LOAD ;从'INPUT1.DAT'中读取数据
;****BEGIN****
MOV DI,OFFSET RESULT ;结果从RESULT开始存放
MOV BX,0
__________________________
PRO: MOV AH,0
MOV AL,SOURCE[BX] ;序列Ak中的一个字节
SUB AL,_______________ ;Ck= Ak-Bk
________ JUMP ;无借位转JUMP
MOV AH,_______________ ;有借位转换成有符号字(为负)
JUMP: MOV ________,AX
ADD DI,2
INC BX
DEC CX
JNZ PRO
;****END****
LEA DX,RESULT ;结果数据区首址
LEA SI,NAME1 ;结果文件名
MOV CX,N*2 ;字节数
CALL SAVE ;保存结果到文件
RET
START ENDP
CODE ENDS
END START
第五十六题:
一、请编制程序,其功能是:求I×J矩阵的转置矩阵(矩阵中元素为字节型),并计算转置矩阵的每一行元素之和,然后存放在每一行最后一个字单元中。
例如:
内存中有 04H,05H,06H,(第一行)01H,02H,03H(第二行)
结果为 04H,01H,05H,00H,05H,02H,07H,00H,06H,03H,09H,00H
部分程序已给出, 其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从RESULT开始存放,由过程SAVE保存到文件OUTPUT1.DAT中。
填空BEGIN和END之间已给出的一段源程序使其完整(空白已用横线标出,每行空白一般只需一条指令, 但采用功能相当的多条指令亦可),或删除BEGIN和END之间原有的代码并自行编程来完成要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生PROG1.EXE执行文件,最终运行程序产生结果(无结果或结果不正确者均不得分)。调试中若发现整个程序中存在错误之处, 请加以修改。
试题程序:
EXTRN LOAD:FAR,SAVE:FAR
N EQU 30
I EQU 3
J EQU 10
DSEG SEGMENT
SOURCE DB N*2 DUP(?)
SRC DW SOURCE
RESULT DB (N+2*J) DUP(0)
NAME0 DB 'INPUT1.DAT',0
NAME1 DB 'OUTPUT1.DAT',0
DSEG ENDS
SSEG SEGMENT STACK
DB 256 DUP(?)
SSEG ENDS
CODE SEGMENT
ASSUME CS:CSEG,SS:SSEG,DS:DSEG
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DSEG
MOV DS,AX
MOV ES,AX
LEA DX,SOURCE ;数据区起始地址
LEA SI,NAME0 ;原始数据文件名
MOV CX,N*2 ;字节数
CALL LOAD ;从'INPUT1.DAT'中读取数据
;****BEGIN****
LEA SI,SOURCE
LEA DI,RESULT
MOV BX,1 ;第一列
LPJ: MOV CX,0 ;累加和
MOV DX,1 ;第一行
LPI: MOV AL,[SI]
ADD CL,AL
___________________________
STOSB
ADD SI,10
INC DX
___________________________
JBE LPI
MOV [DI],CX
___________________________
INC SRC ;下一列
MOV SI,SRC
___________________________
CMP BX,J
JBE __________________
;****END****
LEA DX,RESULT ;结果数据区首址
LEA SI,NAME1 ;结果文件名
MOV CX,(N+2*J) ;字节数
CALL SAVE ;保存结果到文件
RET
START ENDP
CSEG ENDS
END START
第五十七题:
一、请编制程序,其功能是:内存中连续存放的20个8位无符号数是由一个8位A/D转换器采集的信号(X[n],n=0~19),现要求对该信号按下列要求作剔点滤波处现(处理后的信号记为Y[n],n=0~19):
对于第一个信号(n=0)不作滤波,Y[0]=X[0]
对于其后的信号(n>0)
A、 Y[n]=Y[n-1]+delta if X[n]> Y[n-1]+delta
B、 Y[n]=Y[n-1]-delta if X[n]< Y[n-1]-delta
C、 Y[n]=Y[n-1] if |X[n]- Y[n-1]|<=delta
其中delta 取30(1EH)
例如:
Xn:78H,4AH,41H,63H,70H…
Yn:78H,5AH,41H,5FH,70H…
部分程序已给出, 其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从RESULT开始存放,由过程SAVE保存到文件OUTPUT1.DAT中。
填空BEGIN和END之间已给出的一段源程序使其完整(空白已用横线标出,每行空白一般只需一条指令, 但采用功能相当的多条指令亦可),或删除BEGIN和END之间原有的代码并自行编程来完成要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生PROG1.EXE执行文件,最终运行程序产生结果(无结果或结果不正确者均不得分)。调试中若发现整个程序中存在错误之处, 请加以修改。
试题程序:
EXTRN LOAD:FAR,SAVE:FAR
N EQU 20
DELTA EQU 30
STAC SEGMENT STACK
DB 128 DUP(?)
STAC ENDS
DATA SEGMENT
SOURCE DB N DUP(?)
RESULT DB N DUP(0)
NAME0 DB 'INPUT1.DAT',0
NAME1 DB 'OUTPUT1.DAT',0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
MOV ES,AX ;置附加段寄存器
LEA DX,SOURCE ;数据区起始地址
LEA SI,NAME0 ;原始数据文件名
MOV CX,N ;字节数
CALL LOAD ;从'INPUT1.DAT'中读取数据
;****BEGIN****
LEA SI,SOURCE
LEA DI,RESULT
CLD
MOVSB ;Y[0]=X[0]
MOV CX,N-1
FILTER: XOR AX,AX
XOR BX,BX
XOR DX,DX
LODSB ;X[n]
MOV BL,___________ ;Y[n-1]->BL
MOV DL,BL
ADD BX,DELTA ;X[n-1]+delta,符号位扩展
SUB DX,DELTA ;X[n-1]-delta,符号位扩展
CMP AX,BX
J_______ NEXT
_______________________
JMP CONT
NEXT: CMP AX,DX
J_______ STORE
_______________________
JMP CONT
STORE: _______________________
CONT: INC DI
LOOP FILTER
;****END****
LEA DX,RESULT ;结果数据区首址
LEA SI,NAME1 ;结果文件名
MOV CX,N ;字节数
CALL SAVE ;保存结果到文件
RET
START ENDP
CODE ENDS
END START
第五十八题:
一、请编制程序,其功能是:对经常上下波动的数据采用只记录峰值的数据压缩方法,即每次将采样到的当前值和前和前一次值比较,如数据变化方向改变(原变大现变小或原变小现变大),说明已过峰值,这时就将当前值记录下来。
例如(下列数据均为无符号数):
原数据: 23H,45H,89H,67H,5CH,36H,3CH,78H…
压缩后: 23H,67H,3CH…
部分程序已给出, 其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从RESULT开始存放,由过程SAVE保存到文件OUTPUT1.DAT中。
填空BEGIN和END之间已给出的一段源程序使其完整(空白已用横线标出,每行空白一般只需一条指令, 但采用功能相当的多条指令亦可),或删除BEGIN和END之间原有的代码并自行编程来完成要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生PROG1.EXE执行文件,最终运行程序产生结果(无结果或结果不正确者均不得分)。调试中若发现整个程序中存在错误之处, 请加以修改。
试题程序:
EXTRN LOAD:FAR,SAVE:FAR
N EQU 40
STAC SEGMENT STACK
DB 128 DUP(?)
STAC ENDS
DATA SEGMENT
SOURCE DB N DUP(?)
RESULT DB N DUP(0)
NAME0 DB 'INPUT1.DAT',0
NAME1 DB 'OUTPUT1.DAT',0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
MOV ES,AX ;置附加段寄存器
LEA DX,SOURCE ;数据区起始地址
LEA SI,NAME0 ;原始数据文件名
MOV CX,N ;字节数
CALL LOAD ;从'INPUT1.DAT'中读取数据
;****BEGIN****
LEA SI,SOURCE
LEA DI,RESULT
CLD
MOVSB ;Y[0]=X[0]
XOR AX,AX
LODSB ;AL<-X[1]
MOV BL,[SI-2] ;BL<-X[0]
MOV DL,BL
SUB BX,AX ;X[0]-X[1]
MOV DX,BX ;保存差值在DX中
MOV CX,N-2
FILTER: XOR AX,AX
XOR BX,BX
LODSB ;X[n]
MOV BL,[SI-2] ;X[n-1]
SUB BX,AX ;X[n-1]-X[n]
__________________________ ;比较相邻两差值(BX,DX)符号位是否相同
__________________________
J_______ SKIP ;相同,则数据改变方向未变
__________________________ ;不同,方向变化,保存当前值
SKIP: __________________________
LOOP FILTER
;****END****
LEA DX,RESULT ;结果数据区首址
LEA SI,NAME1 ;结果文件名
MOV CX,N ;字节数
CALL SAVE ;保存结果到文件
RET
START ENDP
CODE ENDS
END START
第五十九题:
一、请编制程序,其功能是:内存中连续存放着20个ASCII字符,如果是0~9或A~F之间的字符,请把它们转换成二进制数;若为其他字符,不作转换。
例如:
内存中有: 30H(’0’),23H(’1’),45H(’a’),89H(’A’),67H(’B’)…
结果为: 00H,01H,61H,0AH,0BH…
部分程序已给出, 其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从RESULT开始存放,由过程SAVE保存到文件OUTPUT1.DAT中。
填空BEGIN和END之间已给出的一段源程序使其完整(空白已用横线标出,每行空白一般只需一条指令, 但采用功能相当的多条指令亦可),或删除BEGIN和END之间原有的代码并自行编程来完成要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生PROG1.EXE执行文件,最终运行程序产生结果(无结果或结果不正确者均不得分)。调试中若发现整个程序中存在错误之处, 请加以修改。
试题程序:
EXTRN LOAD:FAR,SAVE:FAR
N EQU 20
STAC SEGMENT STACK
DB 128 DUP(?)
STAC ENDS
DATA SEGMENT
SOURCE DB N DUP(?)
RESULT DB N DUP(0)
NAME0 DB 'INPUT1.DAT',0
NAME1 DB 'OUTPUT1.DAT',0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
LEA DX,SOURCE ;数据区起始地址
LEA SI,NAME0 ;原始数据文件名
MOV CX,N ;字节数
CALL LOAD ;从'INPUT1.DAT'中读取数据
;****BEGIN****
LEA SI,SOURCE
________ DI,OFFSET RESULT
MOV CX,N
NEXT: MOV AL,[SI]
CMP AL,’0’
JB INVALID
CMP AL,________________
JBE ___________________
CMP AL,’A’
JB INVALID
CMP AL,________________
JA ___________________
ADD AL,9
STRIP: AND AL,0FH
INVALID:MOV [DI],AL
ADD SI,1
ADD DI,1
LOOP _____________
;****END****
LEA DX,RESULT ;结果数据区首址
LEA SI,NAME1 ;结果文件名
MOV CX,N ;字节数
CALL SAVE ;保存结果到文件
RET
START ENDP
CODE ENDS
END START
第六十题:
一、请编制程序,其功能是:内存中连续存放着20个无符号字节数,求它们的和。和值按字的形式存放,此前先按序存放参加运算的20个字节。
例如:
内存中有: 01H,02H,03H…
结果为: 02H,02H,03H…(共20 个参加运算的字节),后跟一个字(为前面各20 个字节的和)。
部分程序已给出, 其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从RESULT开始存放,由过程SAVE保存到文件OUTPUT1.DAT中。
填空BEGIN和END之间已给出的一段源程序使其完整(空白已用横线标出,每行空白一般只需一条指令, 但采用功能相当的多条指令亦可),或删除BEGIN和END之间原有的代码并自行编程来完成要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生PROG1.EXE执行文件,最终运行程序产生结果(无结果或结果不正确者均不得分)。调试中若发现整个程序中存在错误之处, 请加以修改。
试题程序:
EXTRN LOAD:FAR,SAVE:FAR
N EQU 20
STAC SEGMENT STACK
DB 128 DUP(?)
STAC ENDS
DATA SEGMENT
SOURCE DB N DUP(?)
RESULT DB N DUP(0)
NAME0 DB 'INPUT1.DAT',0
NAME1 DB 'OUTPUT1.DAT',0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA,SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
LEA DX,SOURCE ;数据区起始地址
LEA SI,NAME0 ;原始数据文件名
MOV CX,N ;字节数
CALL LOAD ;从'INPUT1.DAT'中读取数据
;****BEGIN****
LEA SI,SOURCE
LEA DI,RESULT
MOV CX,N
MOV BX,0
NEXT: MOV AL,[SI]
XOR BX,BX
__________________________
__________________________
MOV [DI],____________
__________________________
__________________________
LOOP NEXT
MOV [DI],____________
;****END****
LEA DX,RESULT ;结果数据区首址
LEA SI,NAME1 ;结果文件名
MOV CX,N+2 ;字节数
CALL SAVE ;保存结果到文件
RET
START ENDP
CODE ENDS
END START
|