请编制程序PROG1.ASM,其功能是:对10个无符号字节数据排序(升序),然后剔除第一个数和最后一个数,并按四舍五入原则计算其余8个数据的算术平均值。将剩余的8个数据存入指定的内存区域中,其后存放平均值。
例如:
内存中有:1,5,4,0,7,9,2,6,8,3
结果为:1,2,3,4,5,6,7,8,5
部分程序已给出,其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从RESULT开始存放,由过程SAVE保存到文件 OUTPUT1.DAT中。
填空BEGIN和END之间已给出的源程序使其完整(空白已用横线标出,每行空白一般只需一条指令,但采用功能相当的多条指令亦可),或删除BEGIN和END之间原有的代码并自行编程来完成要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生PROG1.EXE执行文件,最终运行程序产生结果(无结果或结果不正确者均不得分)。调试中若发现整个程序中存在错误之处,请加以修改。
试题程序:
EXTRN LOAD:FAR, SAVE:FAR
N EQU 10
DSEG SEGMENT
SOURCE DB N DUP(?)
RESULT DB N-1 DUP(0)
NAME0 DB 'INPUT1. DAT',0
NAME1 DB 'OUTPUT 1.DAT',0
TEMP DW 0
DSEG ENDS
SSEG SEGMENT STACK
DB 256 DUP(?)
SSEG ENDS
CSEG SEGMENT
ASSUME CS: CSEG, SS: SSEG, DS: DSEG, ES: 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
CALL LOAD
;*** BEGIN ***
MOV BX, (1)
GOONI: (2)
LEA SI, SOURCE
GOONJ: MOV AL, [SI]
CMP AL, [SI+1]
JLE NEXT
XCHG AL, [SI+1]
MOV [SI], AL
NEXT: ADD SI, 1
LOOP GOONJ
(3)
JNZ GOONI
CLD
LEA SI, SOURCE
LEA DI, RESULT
MOV CX, (4)
INC SI
LP2: LODSB
CBW
ADD TEMP, AX
STOSB
LP1: LOOP LP2
MOV AX, TEMP
(5)
DIV DL
ADD AH, AH
第1题:
一条MTU是1000字节的链路,假设每个数据包有 20字节的头部信息,传输有效载荷为1980字节所需数据包的最小数目是多少?假设先前的数据包是最大尺寸,那么最后一个数据包的大小是多少?
A.3 个数据包,第三个数据包大小为 40 字节
B.3 个数据包,第三个数据包大小为 20 字节
C.2 个数据包,第二个数据包大小为 1000 字节
D.2 个数据包,第二个数据包大小为 980 字节
第2题:
TCP报文中确认序号指的是
A.已经收到的最后一个数据的最后一个字节的序号
B.期望收到对方下一个报文段的第一个数据字节的序号
C.出现错误的字节序号
D.请求重传的数据序号
第3题:
10、一条MTU是1000字节的链路,假设每个数据分组有 20字节的头部信息,传输有效载荷为1980字节所需数据分组的最小数目是多少?假设先前的数据分组是最大尺寸,那么最后一个数据分组的大小是多少?
A.3 个数据包,第三个数据分组大小为 48 字节
B.3 个数据包,第三个数据分组大小为 28 字节
C.2 个数据包,第二个数据分组大小为 976 字节
D.2 个数据包,第二个数据分组大小为 980 字节
第4题:
一条MTU是1000字节的链路,假设每个数据包有 20字节的头部信息,传输有效载荷为1980字节所需数据包的最小数目是多少?假设先前的数据包是最大尺寸,那么最后一个数据包的大小是多少?()
A.3个数据包,第三个数据包大小为20字节
B.2个数据包,第二个数据包大小为980字节
C.3个数据包,第三个数据包大小为40字节
D.2个数据包,第二个数据包大小为1000字节
第5题:
【判断题】存储N个数的一维数组,对这N个数升序排序时,最多需要N-1趟比较交换;对这N个数降序排序时,则需要N趟比较交换
A.Y.是
B.N.否