资源描述:
《计算机等级考试(国家)-三级pc技术机试模拟53》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、三级PC技术机试模拟53上机题丄、请编制程序,将内存屮连续存放着的10个无符号16位二进制数,采用近似计算法求此10个数的近似平方根。方法为:令某个数X依次减去丄,3,5,7,9•…等奇数,一直减到并值刚刚小于等于0为止。计算岀所做的减法的次数Y,即为该数的近似平方根。把得到结果并依次存放到内存当中。例如I:内存中:0010H,0100H,0200H近似方根:0004H,0010H,0016H部分程序已经在PROG1中给出,其中原始数据由过程LOAD从文件INPUT1.DAT+读入,存放在SOURCE开始的内存单元中,转换结果存放在RESULT开始的内
2、存单元中,并由过程SAVE保存到文件OUTPUT1・DAT文件中。对BEGIN和END之间已经给出的源程序填空,使其完整,填空处己经用横线标出,每个空白一般只需填一条指令或指令的一部分;考生也可填入功能相当的多条指令,或删去BEGIN和ENDZ间原有的代码自行编制程序完成相应的要求。对程序必须进行汇编并与IO.OBJ连接产生可执行文件,最终运行程序产生结果(无结果和结果不正确均不得分)。部分源程序如下:EXTRNLOAD:FAR,SAVE:FARNEQU10STACKSEGMENTDB128DUP(?)STACKENDSDATASEGMENTSOURC
3、EDWNDUP(?)RESULTDWNDUP(0)NAME0DB1INPUT1.DAT'z0NAME]DB1OUTPUT1.DAT',0DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATA,SS:STACKSTARTPROCFARPUSHDSXORAX,AXPUSHAXMOVAX,DATAMOVDS;AXLEADX,SOURCELEASI,NAMFOMOVCXZN*2CALLLOAD**********begin**************LEALEAMOVDI,SI,ex,RESULTSOURCENLOOPO:MOVAX,
4、[SI]MOVBX,0LOOP1:(1)SUBAX,STOREOBXSTOREO:INCBX(4)MOV[DI],BXINCDIJ5LINCSIJ6L,LOOPLOOPO***************END*************LEADX,RESULTLEASI,NAME1MOVCX,N*2CALLSAVERETSTARTENDPCODEENDSENDSTART相关知识:•循环程序设计利用重复控制指令可以实现重复操作,能简化程序、节约存储空间。循环程序分为三部分:初始化部分为循环做准备;循环控制部分判断循环条件是否满足,是否继续循环操作;循环体部分
5、完成要循环操作的具体工作。对于复杂问题,单重循坏程序往往不能满足要求,循坏中常常还需要有其他循环程序。值得注意的是内层循环和外层循环Z间应有齐白的控制条件,当从外层循环进入到内层循环时,内层循环的初始条件应该重新设置。(丄)无条件循环指令格式:LOOPDST该指令的功能是,程序执行到此处,CX的内容减1,若CX的内容不为0,则转到目标地址处继续执行指令,否则执行该指令的下一条指令。(2)条件循环指令⑴格式:LOOPZ/LOOPEDST该指令执行后,如果零标志位为1,且CX内容减1后不等于0,则转移到目标地址处继续执行指令,否则执行循坏指令后的一条指令,
6、即零标志位为0或CX内容为0时退出循坏。(ii)格式:LOOPNZ/LOOPNEDST该指令执行时,CX内容减丄,然后根据零标志位和CX内容决定是否循环。若零标志位为1,或CX内容为0时退出循环,否则零标志位等0H.CX内容不等于0,则转移到转移指令的目标地址处继续执行。编程思路:第一步:分析程序要求的功能。本程序需耍完成以下功能:(1)从数据文件INPUT1.DAT+读取10个16位无符号整数存放在SOURCE开始的内存单元屮。(2)将SOURCE开始的10个字单元中的无符号整数,利用减奇数的方法求近似方根,并将结果存放在RESULT开始的内存单元中
7、。(3)将方根结果存放在OUTPUT1.DAT中。第二步:用相应的汇编程序来实现其功能。(1)数据的读取和存入文件的实现,题目中已经给出。(2)对于一个数的方根近似求解,题目中叙述了具体的实现方法,VCB依次减1,3,5・・・•・・直至并小于等于0,求差次数即为方根。通过阅读题目中的汇编源代码,我们可以看出,将内存中的数读入AX,然后循坏减BX中的内容。这样我们可判断出减数1,3,5•・・・・・是存放在BX中的,BX的初始值为1,每执行完一次减操作,BX的内容就应该加2。我们始终没有发现哪一个寄存器是用来计数进行减操作次数的,可实际上BX的内容与减操作
8、的次数是有关的,减操作的次数为((BX)+1)/2。观察出这些特征后,我们就可容易填出空格处的