就业数据资源平台
当前位置:首页 > PC技术
计算机等级考试三级PC上级题精选11-20(4)

上机题之14
以下内容为程序代码:
;*      请编制程序PROG1.ASM, 其功能是: 对一个由可打印ASCII字符
;*  (ASCII码20H~7FH)组成的字符串可采用下列方法进行压缩:从串首
;*  开始向后扫描, 如某字符单独出现则该字符不变, 如某字符连续出
;*  现n次, 则该字符用ESC(1BH),n,<原字符>三个字节来代替(假定n不
;*  超过255)。例如:
;*    原串  : 41H,43H,43H,43H,43H,43H,43H,61H,00H ("ACCCCCCa")
;*    压缩后: 41H,1BH,06H,43H,61H,00H
;*     设内存中从SOURCE开始有一字符串, 其以00H结束, 长度不超
;*  过100。试编程对其进行压缩, 结果存入RESULT开始的内存单元。
;*      部分程序已在PROG1.ASM中给出, 请填空BEGIN和END之间已给
;*  出的源程序使其完整(空白已用横线标出, 每行空白一般只需一条
;*  指令, 但功能相当的多条指令亦可)或删除BEGIN和END之间原有的
;*  代码并自行编写程序片段来完成要求的功能。
;*     原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内
;*  存单元中, 结果要求从RESULT开始存放, 由过程SAVE保存到文件
;*  OUTPUT1.DAT中。
;*     对程序必须进行汇编, 并与IO.OBJ链接产生PROG1.EXE 执行文
;*  件, 最终运行程序产生结果(无结果或结果不正确者均不得分)。
           EXTRN      LOAD:FAR,SAVE:FAR
N          EQU        100
ESC_CODE   EQU        27
STAC       SEGMENT    STACK
           DB         128 DUP (?)
STAC       ENDS
DATA       SEGMENT
SOURCE     DB         N DUP(0)
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,RESULT
           LEA        DI,SOURCE
           CLD
           INC        DI
L0:        mov        al,[di-1]
           ;____________________
           CMP        AL,0
           JE         QUIT
           MOV        CX,0FFFFH         ; SET THE COUNTER TO 0FFFFH
           rep        scasb
           ;____________________         ; 字符串重复搜索, CX=0FFFFH-n
           NEG        CX                ; 10000H-CX->CX
           dec        cx
           ;____________________         ; 获得重复次数n
           CMP        CX,1
           ja        compress
           ;J__        COMPRESS
           MOV        [SI],AL
           INC        SI
           jmp        L0
           ;JMP        ________
COMPRESS:  MOV        [SI],BYTE PTR ESC_CODE
           MOV        [SI+1],CL
           MOV        [SI+2],AL
           add        si,3
           ;____________________
           JMP        L0
QUIT:
           MOV       [SI],AL            ; STORE THE ’’00H’’
;  ****  END  ****
           LEA        DX,RESULT    ; 结果数据区首址
           LEA        SI,NAME1     ; 结果文件名起始地址
           MOV        CX,N         ; 字节数
           CALL       SAVE         ; 保存结果到"output1.dat"文件中
           RET
START      ENDP
CODE       ENDS
           END        START


input1.dat 文件内容如下:
41 42 42 42 65 42 42 42 42 42 42 42 42 42 42 42
42 42 42 42 42 42 42 42 42 42 42 42 42 42 43 44
44 44 45 48 48 48 48 48 48 48 48 48 48 48 48 48
48 48 48 48 48 48 48 48 48 48 48 48 48 48 48 48
48 48 48 48 48 48 49 4A 4C 47 47 47 47 47 47 47
47 47 47 47 47 4D 4D 4D 4D 4D 4D 4D 4D 4D 4D 4D
4D 4D 4D 00
output1.dat 文件内容应当如下:
41 1B 03 42 65 1B 19 42 43 1B 03 44 45 1B 23 48 
49 4A 4C 1B 0C 47 1B 0E 4D 00 00 00 00 00 00 00 
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 
00 00 00 00
就业数据资源平台