首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请编制程序,其功能是:内存中连续存放着20个十六位二进制无符号数序列,请将它们排成升序(从小到大)。 例如: 内存中有:7001H,7004H,7002H,…(假设后17个字均大于7004H) 结果为: 7001H,7002H,7004
请编制程序,其功能是:内存中连续存放着20个十六位二进制无符号数序列,请将它们排成升序(从小到大)。 例如: 内存中有:7001H,7004H,7002H,…(假设后17个字均大于7004H) 结果为: 7001H,7002H,7004
admin
2009-02-15
25
问题
请编制程序,其功能是:内存中连续存放着20个十六位二进制无符号数序列,请将它们排成升序(从小到大)。
例如:
内存中有:7001H,7004H,7002H,…(假设后17个字均大于7004H)
结果为: 7001H,7002H,7004H,…(后跟17个字,按从小到大的顺序排列)
部分程序已给出,其中原始数据由过程LOAD从文件INPUT1.DAT中读入SOURCE开始的内存单元中。运算结果要求从 RESULT开始存放,由过程SAVE保存到文件OUTPUT1.DAT中。
请填空BEGIN和END之间已经给出的源程序使其完整,需填空处已经用横线标出,每个空白一般只需一条指令,也可以填入功能相当的多条指令,或删去BEGIN和END之间原有的代码并自行编程来完成所要求的功能。
对程序必须进行汇编,并与IO.OBJ链接产生可执行文件,最终运行程序产生结果。调试中若发现整个程序中存在错误之处,请加以修改。
[试题程序]
EXTRNLOAD:FAR,SAVE:FAR
N EQU 20
STAC SEGMENT STACK
DB 128 DUP (?)
STAC ENDS
DATA SEGMENT
SOURCE DW N 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 PROCFAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
LEA SI,SOURCE ; 数据区起始地址
LEA SI,NAME0 ; 原始数据文件名
MOV CX,N*2 ; 字数
CALL LOAD ; 从’DAT’中读取数据;
; ********* BEGIN ************
LEA SI,SOURCE
LEA DI,RESULT
MOV CX,N
NEXT0: MOV AX, [SI]
MOV [DI] ,AX
ADD SI, (1)
(2)
LOOP (3)
CLD
MOV BX,N-1
MAL1: LEA SI,RESULT
MOV CX, (4)
NEXT: LOD (5)
CMP [SI] ,AX
JAE CONT
XCHG [SI], (6)
MOV [SI-2],AX
CONT: LOOP (7)
(8)
(9) MALl
; ********* END ********
LEA DX,RESULT ;结果数据区首址
LEA SI,NAME1 ;结果文件名
MOV CX,N*2 ;结果字数
CALL SAVE ;保存结果到文件
RET
START ENDP
CODE ENDS
END START
选项
答案
(1)2 (2)ADD DI,2 (3)NEXT0(4)BX (5)SW (6)AX (7)NEXT (8)DECBX (9)JNZ
解析
所谓“冒泡排序法”就是从第一个数开始与相邻的数进行比较,若两数的顺序已符合要求(本题要求为升序),则不必交换:否则将两数交换。依此类推,直至第n-1个数和第n个数进行过比较为止。上述过程称为第一趟冒泡排序。第一趟冒泡排序经过n-1次比较后,最大的数已经到了数组尾,第二趟仅需比较n-2次就够了,一共比较n-1趟就完成了排序。整个程序共有两重循环:CX控制内循环次数,而BX控制外循环次数。
程序的堆栈段定义了一个128字节的堆栈区,堆栈段下面是数据段。数据段中定义了两个字型变量:原始数据区SOURCE和结果数据区RESULT:两个字节型变量:原始数据文件名NAME0和结果数据文件名NAMEl。数据段下面是代码段,在代码段开始告诉汇编程序,代码段、数据段和堆栈段分别属于段寄存器CS、DS、SS。
因为原始数据和结果数据都是以字型存放的,所以第(1)、(2)空SI和DI地址要分别加2。第(1)空填“2”,第(2)空填“ADD DI,2”。接着开始循环,循环入口处是NEXT0,所以第(3)空填写“NEXT0”。第(3)空之前的几条指令是实现将原始数据区SOURCE中的数据依次装入到RESULT中。
CLD指令是将方向标志DF清0,以便在执行串操作指令时,实现地址指针自动增量。
MALl段和NEXT段是实现每趟内的数据比较。第一趟比较N-1次后,最大的数已到了末尾,第二趟仅需比较N-2次就够了,所以CX是随着BX变化的。
第(5)空是需要将由SI作为地址指针的字单元的内容装入到AX中,同时SI自动加2,指向下一个字单元。接下来将下一个数与当前的数进行比较,若大于,则继续循环,取下一个数:若小于,则两数交换。所以第(6)空应该填写“AX”。第 (7)、(8)、(9)空是完成一趟比较后,BX应减1,若BX不为0,则继续循环,进行第二趟比较,循环入口处是NEXT。所以第(7)空填写“NEXT”,第(8)空填写“DEC BX”,第(9)空填写“JNZ”。
转载请注明原文地址:https://jikaoti.com/ti/sLV7FFFM
本试题收录于:
三级PC技术题库NCRE全国计算机三级分类
0
三级PC技术
NCRE全国计算机三级
相关试题推荐
中断是计算机硬件与操作系统之间进行通信的主要手段,中断处理可分为保护断点保留现场、分析中断源确定中断原因、______和中断返回四个阶段。
JamesMartin认为下列哪些措施是解决数据处理部门与最高管理层之间的隔阂Ⅰ.聘请咨询公司Ⅱ.为最高管理层放映录像并推荐一本信息系统建设的书Ⅲ.开设高级管理人员培训班Ⅳ.与高层管理人员通信、沟通
以下关于操作型数据和分析型数据的描述中,正确的是
软件测试的内容很多。Ⅰ.系统测试Ⅱ.有效性测试Ⅲ.单元测试Ⅳ.验收测试Ⅴ.集成测试以上测试内容中主要依据软件总体结构完成的测试工作应该是
作为一个庞大的系统软件,DBMS由众多程序模块组成,它们分别实现DBMS复杂而繁多的功能。其中完整性控制程序属于下列()程序模块。
下列是关于信息系统开发策略的假设。Ⅰ.所有需求能被预先定义Ⅱ.有快速的系统建设工具Ⅲ.项目参加者之间通常能够清晰地进行通信Ⅳ.需要实际的、可供用户参与的系统模型Ⅴ.大量的反复是不可避免的,应该加以鼓励以上假设中,属于原型化方法
操作系统为一组()。
总体设计是在()工作的基础上进行的。
操作系统中对文件的保护一般设立文件存取的两级控制:第一级是对访问者的识别,第二级是对【】的识别。
战略数据规划方法中建立的企业模型包含三个方面的内容:职能范围、业务活动过程、业务活动。以下关于这三个内容关系的描述中,正确的是
随机试题
自截肾常见的疾病是
造成垂直型食物嵌塞的主要原因是
保税货物和减免税货物均属于海关监管货物,但海关对前者实行时效管理,对后者实行核销管理。()
下列关于股票增长率模型的说法,正确的有()。Ⅰ.零增长模型是不变增长模型的一个特例Ⅱ.假定增长率g=0,股利将永远按固定数量支付Ⅲ.不变增长的假设比零增长的假设有较小的应用限制,但在许多情况下被认为是不现实的Ⅳ.不变增长模型是多
中国最早用蒙古文写成的历史文献和文学巨著(),已被联合国教科文组织定为世界著名文化遗产。
某公司在股东大会中选举董事长,在选举前的民意调查中,张某获得56%的支持.王某获得44%的支持,但选举结果显示张某得票率仅占37%,王某得票率为63%。这说明,民意调查在操作上出现了失误。以下哪项为真,最能削弱上述论断?
下图表示的是某山垂直自然带的分布,读图回答下列问题。图中①②③依次代表()。
当小机器人“金字塔漫游者”吃力地沿着长约64米的“南通道”独自向上攀爬时,这段90分钟的孤独之旅显得格外漫长,一如这昏暗的甬道本身的寿命。“人畏惧时间,而时间畏惧金字塔”这句阿拉伯谚语的真意,在此刻突显无疑。这段话意在强调( )。
A、有教无类B、温故而知新C、学而时习之D、弟子事师,敬同于父D“弟子事师,敬同于父”是在西周时期提出的,不是孔子的话。
A、Halfoftheyoungmenaresmokers.B、Two-thirdsofyoungmenwilldiefromsmoking.C、Manymenbegintosmokeintheirmiddle
最新回复
(
0
)