ImageVerifierCode 换一换
格式:DOC , 页数:5 ,大小:30.50KB ,
资源ID:1320148      下载积分:5000 积分
快捷下载
登录下载
邮箱/手机:
温馨提示:
如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝扫码支付 微信扫码支付   
注意:如需开发票,请勿充值!
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【http://www.mydoc123.com/d-1320148.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(【计算机类职业资格】三级PC技术机试-163及答案解析.doc)为本站会员(dealItalian200)主动上传,麦多课文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知麦多课文库(发送邮件至master@mydoc123.com或直接QQ联系客服),我们立即给予删除!

【计算机类职业资格】三级PC技术机试-163及答案解析.doc

1、三级 PC 技术机试-163 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.编制一个程序,其实现的功能为:计算 10 个带符号字节数据的绝对值之和(和为字型),并且找出绝对值最小的数及其所在的偏移地址,将结果依次存入指定的内存区中,结果以 0FH 结束。例如:内存中有:23H, 14H,00H,08H,PEH, 87H,02H,01H,PPH,01H结果为: BFH,00H,00H,02H,00H,0FH部分程序已经给出,原始数据由过程 LOAD 从文件 INPUT.DAT 中读入以 SOURCE 开始的内存单元中。运算结果要求从 RES

2、ULT 开始的内存单元存放, 由过程 SAVE 保存到文件 OUTPUT.DAT 中。请填空 BEGIN 和 END 之间已给出的源程序使其完整,空白已经用横线标出,每行空白一般只需要一条指令,但采用功能相当的多条指令也行,考生也可以删除 BEGIN 和 END 之间原有的代码并自行编程来完成要求的功能。对程序必须进行汇编,并与 IO.OBJ 链接产生可执行文件,最终运行程序产生结果。调试中若发现整个程序中存在错误之处,请加以修改。试题程序EXTRN LOAD:FAR,SAVE:FARN EQU 10DSEG SEGMENTSOURCE DB N DUP(?)RESULT DB 6 DUP(0

3、)MIN DB ?NAME0 DB INPUT.DAT,0NAME1 DB OUTPUT.DAT,0DSEG ENDSSSEG EGMENT STACKDB 256 DUP(?)SSEG ENDS CSEG SEGMENT ASSUME CS:CSEG,DS:DSEG,SS:SSEGSTART PROC FARPUSH DSXOR AX,AXPUSH AXMOV AX,DSEGMOV DS,AXLEA DX,SOURCELEA SI,NAME0MOV CX,NCALL LOAD; * BEGIN *LEA SI,SOURCELEA DI,RESULTMOV DX,SIMOV CX,N-1MOV

4、 AL,SISUB AX,0JNS NEXTNEG ALNEXT: MOV MIN,ALADD DI,AL(1) AGAIN: INC SIMOV AL,SIADD AL,0JNS NEXT1(2) NEXT1: ADD DI,AL(3) CMP MIN,ALJBE NEXT2MOV MIN,AL(4) NEXT2: LOOP AGAINADD DI,2MOV AL,MINMOV DI,ALINC DIMOV DI,DXADD DI,2MOV (5) ,0FH* END *LEA DX,RESULTLEA SI,NAME1MOV CX,6CALL SAVERET START ENDPCSEG

5、ENDSEND START(分数:100.00)_三级 PC 技术机试-163 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.编制一个程序,其实现的功能为:计算 10 个带符号字节数据的绝对值之和(和为字型),并且找出绝对值最小的数及其所在的偏移地址,将结果依次存入指定的内存区中,结果以 0FH 结束。例如:内存中有:23H, 14H,00H,08H,PEH, 87H,02H,01H,PPH,01H结果为: BFH,00H,00H,02H,00H,0FH部分程序已经给出,原始数据由过程 LOAD 从文件 INPUT.DAT 中读入以 SOU

6、RCE 开始的内存单元中。运算结果要求从 RESULT 开始的内存单元存放, 由过程 SAVE 保存到文件 OUTPUT.DAT 中。请填空 BEGIN 和 END 之间已给出的源程序使其完整,空白已经用横线标出,每行空白一般只需要一条指令,但采用功能相当的多条指令也行,考生也可以删除 BEGIN 和 END 之间原有的代码并自行编程来完成要求的功能。对程序必须进行汇编,并与 IO.OBJ 链接产生可执行文件,最终运行程序产生结果。调试中若发现整个程序中存在错误之处,请加以修改。试题程序EXTRN LOAD:FAR,SAVE:FARN EQU 10DSEG SEGMENTSOURCE DB N

7、 DUP(?)RESULT DB 6 DUP(0)MIN DB ?NAME0 DB INPUT.DAT,0NAME1 DB OUTPUT.DAT,0DSEG ENDSSSEG EGMENT STACKDB 256 DUP(?)SSEG ENDS CSEG SEGMENT ASSUME CS:CSEG,DS:DSEG,SS:SSEGSTART PROC FARPUSH DSXOR AX,AXPUSH AXMOV AX,DSEGMOV DS,AXLEA DX,SOURCELEA SI,NAME0MOV CX,NCALL LOAD; * BEGIN *LEA SI,SOURCELEA DI,RESU

8、LTMOV DX,SIMOV CX,N-1MOV AL,SISUB AX,0JNS NEXTNEG ALNEXT: MOV MIN,ALADD DI,AL(1) AGAIN: INC SIMOV AL,SIADD AL,0JNS NEXT1(2) NEXT1: ADD DI,AL(3) CMP MIN,ALJBE NEXT2MOV MIN,AL(4) NEXT2: LOOP AGAINADD DI,2MOV AL,MINMOV DI,ALINC DIMOV DI,DXADD DI,2MOV (5) ,0FH* END *LEA DX,RESULTLEA SI,NAME1MOV CX,6CALL

9、 SAVERET START ENDPCSEG ENDSEND START(分数:100.00)_正确答案:(1)ADC BYTE PTR DI+1,0 (2)NEG AL (3)ADC BYTE PTR DI+1,0 (4)MOV DX,SI (5)BYTE PTR DI)解析:解析程序的整体结构是:先对数据进行判断,若是正数,则直接求和,否则求补以后再进行相加。并且对每个数的绝对值进行比较,绝对值最小的数放在 MIN 中,绝对值最小数的偏移地址放在 DX 中。程序开始进行的是指针的初始化,SI 中为 SOURCE 的偏移地址,DI 中为 RESULT 的偏移地址,并将 SOURCE中第一个

10、存储单元的数据和地址分别放在 AL 和 DX 中。第一个数装入以后,需要对其进行判断,如果为正数的话,可以接着执行下面的程序段,否则就求出它的绝对值(即对其进行求补操作)。完成操作以后,就可以把第一个数当成比较对象和其他值的绝对值进行比较。首先将 AL 中的数放入 MIN 中,然后将其加到RESULT 的第一个单元中(即 DI 所指的地址单元中),在执行加法运算时,要将其进位也加进去,所以第一个空白处应该填的内容是对进位进行相加,即 ADC BYTE PTRDI +1,0。从第二个数据开始,程序进入循环,即后面的数将执行同一操作:判断是否为正数,若是正数,则直接加入 DI 所指的单元,否则求补

11、以后再加入。同时,把数据的绝对值与 MIN 中的内容进行比较,如果数据的绝对值小于 MIN 则将数据放入 M1N 中,并且把此时的偏移地址 SI 存入 DX 中,否则执行下一次加法与比较操作。因此,对于 24 个空缺处来说,需要完成的就是上述的操作。执行完加法操作和找出绝对值最小的数以后,接下来便是按照要求对结果进行存储。由于题目要求最后一个存储单元为 0FH,所以最后一步操作应该是存入 0FH。由于此时 DI 已经指向 RESULT 的最后一个单元,因此可以直接存入。但需要注意的是不能使用 MOV DI,0FH 的语句,因为这样将不知道是把 0FH 存入DI单元,还是把 0FH 和 00H 存入DI和DI+1单元,所以应该指定操作数的类型,即 MOV BYTE PTR DI,0FH。

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1