请编制程序,其功能是:对一个由可打印ASCII字符(ASCII值为20H~7FH)组成的字符串可采用下列方法进
请编制程序,其功能是:对一个由可打印ASCII字符(ASCII值为20H~7FH)组成的字符串可采用下列方法进行压缩:从串首开始向后扫描,如某字符单独出现则该字符不变,如某字符连续出现n次,则该字符用ESC(1BH),n,<原字符>三个字节来代替(假定n不超过255)。
设内存中从SOURCE开始有一用上述方法压缩的字符串,其以OOH结束,解压后长度不超过100。试编程对其解压缩,结果存入RESULT开始的内存单元。
例如:
原串: 41H,1BH,06H,43H,61H,00H
解压缩后:41H,43H,43H,43H,43H,43H,43H,61H,OOH("ACCCCCCa")
部分程序已给出,原始数据由过程LOAD从文件INPUT.DAT中读入SOURCE开始的内存单元中,结果要求从RESULT开始存放,由过程SAVE保存到文件OUTPUT.DAT中。
请填空BEGIN和END之间已给出的源程序使其完整,空白己用横线标出,每个空白一般只需一条指令,但采用功能相当的多条指令亦可,或删除BEGIN和END之间原有的代码并自行编写程序片段来完成所要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生可执行文件,最终运行程序产生结果。调试中若发现整个程序中存在错误之处,请加以修改。
【试题程序】
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(?)
RESULT DB N DUP(0)
NAME0 DB 'INPUT.DAT',0
NAME1 DB 'OUTPUT.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 ;从"INPUT.DAT" 中读取数据
******** BEGIN ********
LEA SI, SOURCE
LEA DI, RESULT
CLD
LO: LODSB
CMP AL, 0
JE QUIT
CMP AL, ESC_CODE
J (1) EXPAND
(2)
JMP L0
EXPAND: (3)
(1)E (2)STOSB (3)CID (4)MOV CL,[SI] (5)MOV AL,[SI+1] (6)REP STOSB (7)ADD SI,2 解析:本题是一道数据插入题,其中本题采用的算法是首先从原始数据区读取一个字节,判断是否为结束标志,若是结束标志,则直接送至结果数据区并结束处理,若不是结束标志则再次判断是否是压缩标志,是则读取下一个字节,然后将其值送CL,再读取下一个字节到AL,以CL为计数器重复将刚才读取的数据写入结果数据区,然后继续读取下一个数据开始进行判断,直到发现结束标志为止。反之则直接将该字符送到结果数据区。
程序中使用串处理指令LODSB来完成读取数据和修改原始数据区偏移地址的目的:使用串处理指令STOSB来完成写入数据和修改结果数据区偏移地址的目的;使用CL做计数器和指令REP完成循环处理。
如图是由常见元素组成的一些单质及其化合物之间的转化关系图.常温常压下,B、E、F、H、I均为气体, 化学 2020-05-13 …
当时间由t=0增加到t=1时,人口增长了i%,由t=1增加到t=2时,人口增长了j%,这样,当时间 数学 2020-05-14 …
如图(图请自己画.),在△ABC中,AB=AC=2,BC边上有1999个不同的点P1,P2,…P1 数学 2020-05-20 …
图中A~I是初中化学常见的物质,且分别是由H、C、O、Na、Al、S、Ca、Cu、Ag中的一种或几 化学 2020-06-12 …
某锂碘电池以LiI-Al2O3固体为电解质传递离子,其基本结构示意图如下,电池总反应可表示为:2L 化学 2020-07-29 …
统计学中的AI、TI(i均为下标)分别指什么如题 数学 2020-07-29 …
如果f(x)在某个区间I内满足:对任意的,则称f(x)在I上为下凸函数;已知函数(Ⅰ)证明:当a> 数学 2020-07-29 …
(理)如果f(x)在某个区间I内满足:对任意的x1、x2∈I都有[f(x1)+f(x2)]≥f() 数学 2020-07-29 …
记I为虚数集,设a,b∈R,x,y∈I.则下列类比所得的结论正确的是()A.由a•b∈R,类比得x• 其他 2020-11-29 …
一道由初中数列题改编的高中联赛踢a[0]=3a[n+1]=a[n]^2-n*a[n]+1n>=0求和 数学 2020-12-05 …