汇编语言 廖建明编 课后习题第五章习题答案

合集下载

第五章习题答案

第五章习题答案

5.1 顺序分支循环5.2 (AX)=5400H (BL)=06H (DX)=2106H5.3 D5.4 C5.5 B5.6 D5.7 C5.8 0FFH 05.9 C5.10 略5.11 B5.12 A5.13 23H 01H 56H 04H 00H5.14 将BUF里的小写字母转换成大写字母5.15 (1)(AX)= 0A20H, (BX)=0003H, (CX)=0000H, (DX)=0000H {循环4次}(2)(AX)= 0A20H, (BX)=0003H, (CX)=0000H, (DX)=0000H {循环4次}(3)(AX)=000CH, (BX)=0003H, (CX)=0003H, (DX)=0000H {循环1次}5.16 (1)完成85274AH与938765H的加法功能(2)不能。

INC对CF无影响,而ADD有影响(3)MOV SI,OFFSET DA TA1(4)置CF为零。

若CF初始为1,则在第一次执行ADC指令时会产生不正确的结果。

5.17(编程题为参考答案,下同)DA TA SEGMENTDA TA1 DB ?DA TA2 DB ?DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN:MOV AX,DATAMOV DS,AXMOV DX,DATA1;高位送DXMOV AX,DATA2;低位送AXSHL AX,1;RCL DX,1;MOV AH,4CHINT 21HCODE ENDSEND BEGIN5.18DA TA SEGMENTDA TAS DB ‘PLEAST INPUT:’,0DH,0AH, ‘$’DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN: MOV AX,DA TAMOV DS,AXMOV AH,9HINT 21H ;输出“PLEASE INPUT:”MOV AH,1INT 21H ;用户输入MOV DL,ALSUB DL,20HMOV AH,2INT 21H ;显示输出MOV AH,4CHINT 21HCODE ENDSEND BEGIN5.19DA TA SEGMENTARRAY DB 20 DUP(?);原数列PLUS DB 20 DUP(0);存放正数NEGA DB 20 DUP(0);存放负数PLUS_N DB 0;指示正数个数NEGA_N DB 0;指示负数个数TIME DB 20DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN: MOV AX,DA TAMOV DS,AXLEA SI,ARRAYLEA BX,PLUSLEA DI,NEGAMOV CX,TIMECLC;以上为初始化LOOP1: MOV AL,[SI]CMP AL,0INC SIJA DAYUJB XIAOLOOP LOOP1;等于零处理JMP SHOWDAYU: MOV [BX],AL;大于零的处理INC BXINC PLUS_NLOOP LOOP1JMP SHOWXIAOYU:MOV [DI],AL;小于零的处理INC DIINC NEGA_NLOOP LOOP1SHOW: MOV DL,PLUS_N;屏幕显示输出MOV AH,2INT 21HMOV DL,NEGA_NMOV AH,2INT 21HMOV AH,4CHINT 21HCODE ENDSEND BEGIN5.20STACK SEGMENT PARA STACKDB 10H DUP(0)STACK ENDSCODE SEGMENTASSUME CS:CODE,SS:STACKBEGIN: PUSHF;标志位入压入栈POP AX;出栈到AXEXCHANGE AH,AL;高低位互换PUSH AX;AX压入栈POPF;弹出到标志寄存器CODE ENDSEND BEGIN5.21DA TA SEGMENTSTR DB ‘INPUT 1 OR 0’,0DH,0AH,‘$’BUFF DB 20 DUP(0)LEN DW 10DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN: MOV AX,DA TAMOV DS,AXMOV DX,OFFSET STRMOV AH,09HINT 21HMOV BH,48;零的ASCII码MOV BL,65;A的ASCII码LEA SI,BUFFMOV CX,LENMOV AH,1HINT 21HCMP DL,1JZ ACMP DL,2JZ BJMP END0;输入非1非2即结束程序A: MOV [SI],BHINC SIMOV [SI],BLINT SIMOV DL,BHMOV AH,2INT 21HMOV DL,BLMOV AH,2INT 21HINC BHINC BLLOOP AJMP END0B: MOV [SI],BLINC SIMOV [SI],BHINC SIMOV DL,BLMOV AH,2INT 21HMOV DL,BHMOV AH,2INT 21 HINC BLINT BHLOOP BEND0: MOV AH,4CHINT 21HCODE ENDSEND BEGIN5.22DA TA SEGMENTX DB ?Y DB ?Z DB ?SUM DB 0DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TA BEGIN: MOV AX,DA TAMOV DS,AXMOV AX,XADD AX,YCMP AX,200MOV AX,XJG SUB0;判断ADD AX,ZJMP END0SUB0: SUB AX,ZEND0: MOV SUM AXMOV AH,4CHINT 21HCODE ENDSEND BEGIN5.23略。

第5章习题参考答案.doc

第5章习题参考答案.doc

第5章习题参考答案1.请在括号内填入适当答案。

在CPU中:(1)保存当前正在执行的指令的寄存器是(IR );(2)保存当前正在执行的指令地址的寄存器是(AR )(3)算术逻辑运算结果通常放在(DR )和(通用寄存器)。

2.参见图5.15的数据通路。

画出存数指令“STO Rl,(R2)”的指令周期流程图,其含义是将寄存器Rl的内容传送至(R2)为地址的主存单元中。

标出各微操作信号序列。

解:STO R1, (R2)的指令流程图及为操作信号序列如下:STO R1, (R2)R/W=RDR O, G, IR iR2O, G, AR iR1O, G, DR iR/W=W3.参见图5.15的数据通路,画出取数指令“LAD (R3),R0”的指令周期流程图,其含义是将(R3)为地址主存单元的内容取至寄存器R2中,标出各微操作控制信号序列。

解:LAD R3, (R0)的指令流程图及为操作信号序列如下:PC O , G, AR i R/W=R DR O , G, IR iR 3O , G, AR i DR O , G, R 0iR/W=R LAD (R3), R04.假设主脉冲源频率为10MHz ,要求产生5个等间隔的节拍脉冲,试画出时序产生器的逻辑图。

解:5.如果在一个CPU 周期中要产生3个节拍脉冲;T l =200ns ,T 2=400ns ,T 3=200ns ,试画出时序产生器逻辑图。

解:取节拍脉冲T l 、T 2、T 3的宽度为时钟周期或者是时钟周期的倍数即可。

所以取时钟源提供的时钟周期为200ns ,即,其频率为5MHz.;由于要输出3个节拍脉冲信号,而T 3的宽度为2个时钟周期,也就是一个节拍电位的时间是4个时钟周期,所以除了C 4外,还需要3个触发器——C l 、C 2、C 3;并令211C C T *=;321C C T *=;313C C T =,由此可画出逻辑电路图如下:6.假设某机器有80条指令,平均每条指令由4条微指令组成,其中有一条取指微指令是所有指令公用的。

汇编 第五章基本结构程序设计参考答案.ppt

汇编 第五章基本结构程序设计参考答案.ppt

BUF DW 16
NUM DW ?
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
BEGIN:MOV AX,DATA
MOV DS, AX
MOV AX, [BX]
MOV BX , OFFSET AQTAB
MOV NUM , AX
MOV AX, BUF
INC BUF2
DATA ENDS
JMP EXIT
CODE SEGMENT
JIAOHUAN:MOV BUF1,BL
ASSUME DS:DATA
MOV BUF2,AL
ASSUME CS:CODE
EXIT: MOV AH,4CH
START:MOV AX,DATA
INT 21H
MOV DS,AX
MOV SI,OFFSET BUF
MOV CX, CNT
MOV AX, 0
MOV SUM, AL
MOV AH, 4CH
INT 21H
CODE ENDS
END START
P102_58
DATA SEGMENT
X DW -123
Y DW 50
Z DW 1234H
DATA ENDS
CODE SEGMENT
CODE ENDS
MOV AL,BUF1
END START
MOV BL,BUF2
TEST BL,01H
JZ EXIT ;BUF2中为偶数
TEST AL,01H
JZ JIAOHUAN
;BUF1中偶数,BUF2为奇数
P102_57
DATA SEGMENT
BUF DB 30H,02H,10H,11H,56H,78H,65H,54H,85H,19H

汇编第五章课后题答案

汇编第五章课后题答案

1.从屏幕上输入小写字母,转化为大写字母输出(解法1)DATA SEGMENTMESSAGE DB "ENTER A STRING:",0AH,0DH,'$' MAXLENGTH DB 50,?,50 DUP(?) ;每次最多可以输入49个字符DATA ENDSCODE SEGMENTASSUME DS:DATA,CS:CODESTART:MOV AX,DATAMOV DS,AXLEA DX,MESSAGE ;输出ENTER A STRINGMOV AH,09HINT 21HLEA DX,MAXLENGTH ;输入字符串MOV AH,0AH ;键盘输入到缓冲区,DS:DX=缓冲区首址INT 21H ;(DS:DX)=缓冲区最大字符数,(DS:DX+1)=实际输入的字符数MOV AH,02H ;输出回车换行MOV DL,0AHINT 21HMOV AH,02HMOV DL,0DHINT 21HMOV CL,MAXLENGTH+1;把字符的实际长度放入寄存器CLMOV CH,0MOV BH,02HLEA SI,MAXLENGTH+2;取字符串的基地址放入SIXUN:MOV AL,[SI]CMP AL,'Z'JBE S1 ;小于等于'Z'转移JMP S3S1:CMP AL,'A'JAE DA ;大于等于'A'转移JMP OUTPUTDA:ADD AL,20HJMP OUTPUTS3:CMP AL,'z' ;小于等于小Z转移JBE S4S4:CMP AL,'a' ;大于等于小a转移JAE XIAOJMP OUTPUTXIAO:SUB AL,32JMP OUTPUTOUTPUT:MOV DL,ALMOV AH,02H ;显示输出INT 21HINC SILOOP XUNMOV AH,4CHINT 21HCODE ENDSEND START(解法2);将输入的小写字母转化为大写字母输出,输入回车结束CODE SEGMENTASSUME CS:CODEBEGIN:MOV AH,01HINT 21HCMP AL,0DH ;ASCII OF CARRIAGE RETURNJE EXITCMP AL,61H ;ASCII OF 'a'JB STOPCMP AL,7AH ;ASCII OF 'z'JA STOPSUB AL,20HSTOP:MOV DL,ALMOV AH,2INT 21HJMP BEGINEXIT:MOV AH,4CHINT 21HRETCODE ENDSEND BEGIN2.输入一个字符,找出它的前导字符和后续字符,并按顺序显示这三个字符.(解法1)CODE SEGMENTMAIN PROC FARASSUME CS:CODESTART:PUSH DSXOR AX,AXPUSH AXMOV AH,01HINT 21HCMP AL,61HJB EXITCMP AL,7AHJA EXITMOV CL,ALDEC ALMOV DL,ALMOV AH,02HINT 21HMOV DL,CLMOV AH,02HINT 21HAND AL,01HINC CLMOV DL,CLMOV AH,02HINT 21HEXIT:MOV AX,4C00HINT 21HRETMAIN ENDPCODE ENDSEND START(解法2).MODEL SMALL.STACK 200H.DATAimsg db 'Input:$' ;输入提示信息omsg db 0Dh,0Ah,'Output:$' ;输出提示信息string db 3 dup(0),'$' ;存放三个字符.CODESTART:mov ax,@datamov ds,axlea dx,imsgmov ah,9int 21hmov ah,1int 21hlea di,stringdec almov cx,3s:mov [di],alinc diinc alloop slea dx,omsgmov ah,9int 21hlea dx,stringmov ah,9int 21hMOV AH,07HINT 21HMOV AX,4C00HINT 21HEND START3.将AX寄存器中的16位数分成4组,每组4位,然后把这四组数分别放在AL,BL,CL,DL中.MODEL SMALL,C.CODE.STARTUPMOV AX,3456HMOV BX,AXMOV CL,4ROL AX,CLMOV BX,AXAND AL,0FH ;AL中是15,14,13,12ROL BX,CLMOV DX,BXAND BL,0FH ;BL中是11,10,9,8AND AH,0FHMOV CH,AH ;CH中是7,6,5,4MOV CL,CHAND DH,0FH ;DH中是3,2,1,0MOV DL,DH.EXIT 0END4.试编写一程序,要求比较两个字符串STRING1和STRING2所含字符是否相同,若相同则显示'MATCH',若不相同则显示'NOT MATCH'..MODEL SMALL.DATASTRING1 DB "LDSKFJSLDKF"LENG1 EQU $-STRING1STRING2 DB "LDSKFJSLDKP"LENG2 EQU $-STRING2MSG1 DB "MATCH",24HMSG2 DB "NOT MATCH",24H.CODEMOV AX,@DATAMOV DS,AXMOV ES,AXMOV BX,LENG1MOV CX,LENG2CMP BX,CXJNZ NOT_MATCHLEA SI,STRING1LEA DI,STRING2CLDREPZ CMPSBJZ _MATCHNOT_MATCH:LEA DX,MSG2MOV AH,09HINT 21HJMP _EXIT_MATCH:LEA DX,MSG1MOV AH,09HINT 21H_EXIT:MOV AH,07HINT 21HMOV AX,4C00HINT 21HEND5.要求能从键盘接收一个个位数,然后响铃N次(响铃的ASCII码为07) .MODEL SMALL.DATAMSG DB "YOUR INPUT IS NOT 1-9!",24H .CODE.STARTUPMOV AH,0INT 16H ;接收一个键盘输入CMP AL,31HJB ERRORCMP AL,39HJA ERRORMOV CL,ALSUB CL,30HCYCLE:MOV DL,7MOV AH,09HINT 21HMOV AH,07H ;按一下键就响一下铃声INT 21HLOOP CYCLEJMP _EXITERROR:LEA DX,MSGMOV AH,09HINT 21HMOV AH,07HINT 21H_EXIT:.EXIT 0END6.编写程序,将一个包含有20个数据的数组M分成两个数组,正数数组P 和负数数组N,并分别把这两个数组中数据的个数显示出来..MODEL SMALL,C.DATAINDEX DB 12,-20,4,05H,11H,2AH,-11,2,3,09HDB -3,0,-9,44H,32H,33H,34H,-5,40H,22HP DB 0,20 DUP(0) ;存放正数N DB 0,20 DUP(0) ;存放负数.CODEDISPLAY PROC NEAR USES AXAND AH,0FH.IF AH>= 0AH && AH<= 0FHADD AH,07H.ENDIFADD AH,30HMOV DL,AHMOV AH,02HINT 21HMOV AH,07HINT 21HRETDISPLAY ENDP.STARTUPLEA DI,P+1LEA SI,N+1LEA BX,INDEXMOV CX,14HCYCLE:CMP BYTE PTR [BX],0JG NOSIGNINC AL ;AL中存放负数MOV DL,BYTE PTR [BX]MOV BYTE PTR DS:[DI],DLINC DIINC BXLOOP CYCLENOSIGN:INC AH ;AH中存放正数MOV DL,BYTE PTR [BX]MOV BYTE PTR DS:[SI],DLINC SIINC BXLOOP CYCLEMOV P,AHMOV N,ALCALL DISPLAYMOV AH,ALCALL DISPLAY.EXIT 0END7.试编制一个汇编语言程序,求出首地址为DATA的100D字数组中的最小偶数,并把它存放在AX中.datarea segmentdata dw 10,2,4,8,7,7,69,65,55,89,95dw 25,39,77,88,25,1,47,88,8,8,77,88,22 count=($-data)/2num dw 0ffeehdatarea endscode segmentmain proc farassume cs:code,ds:datareapush dsmov ax,0push axbegin:mov ax,datareamov ds,axmov bl,2mov cx,countlea si,dataA:mov ax,[si]mov dx,axdiv blcmp ah,0jne circlecmp dx,numjb Bcircle:add si,2lopa:loop Aexit:mov ax,numretB:mov num,dxjmp lopamain endpcode endsend8.把AX中存放的16位二进制数K看作是8个二进制的"四分之一字节".试编写一程序,要求数一下值为3(即11B)的四分之一字节数,并将该数在终端上显示出来.MOV CX,8MOV DL,0NEXT3:ROR AX,1JNC NEXT1ROR AX,1JNC NEXT2INC DLNEXT2:LOOP NEXT3ADD DL, 30HMOV AH, 2INT 21HMOV AH, 4CHINT 21HNEXT1:ROR AX, 1JMP NEXT29.试编写一汇编语言程序,求出首地址为DATA的100D字数组中的最小偶数,并把它存放在AX中..MODEL SMALL,C.DATA_DATA DW 100 DUP(?).CODE.STARTUPLEA SI,_DATAMOV AX,[SI]MOV CX,100CYCLE:ADD SI,2.IF AX< [SI]MOV AX,[SI].ENDIFLOOP CYCLE.EXIT 010.设有一段英文,其字符变量名为ENG,并以$字符结束,试编写一程序,查对单词SUN在该文中的出现次数,并以格式"SUN****"显示出次数..MODEL SMALL.386.DATAENG DB 'SUN','SUN JAVA',24HMESSAGE DB 'SUN:','$' .STACK 100H.CODEMAIN PROC FAR START:PUSH DSAND AX,0PUSH AXMOV AX,@DATAMOV DS,AXMOV AX,0HMOV SI,1HSUBSI1:SUB SI,1HSUBSI2:SUB SI,1H COMPARES:ADD SI,1HMOV DL,ENG[SI]CMP DL,24HJE PRINTCMP DL,53HJNE COMPARES COMPAREU:ADD SI,1HMOV DL,ENG[SI]CMP DL,55HJNE SUBSI2 COMPAREN:ADD SI,1HMOV DL,ENG[SI]CMP DL,4EHJNE SUBSI1INC AXJMP COMPARESPRINT:LEA DX,MESSAGEPUSH AXMOV AH,09HINT 21HPOP AXCALL SHOWNUMBER EXIT:RETMAIN ENDP SHOWNUMBER PROC NEAR COVERNUM:DAAMOV DX,AXMOV CL,4HSHOW:ROL DX,4HPUSH DXAND DX,0FHADD DX,30HMOV AH,02HINT 21HPOP DXLOOP SHOWRETSHOWNUMBER ENDPEND START11.从键盘输入一系列以$为结束符的字符串,然后对其中的非数字字符计数,并显示出计数结果..MODEL SMALL.386.CODEMAIN PROC FARSTART:PUSH DSMOV AX,0PUSH AXMOV CX,0INPUT:MOV AH,1HINT 21HCOMPARE:CMP AL,24HJE PRINTCMP AL,30HJL ADDCOUNTCMP AL,39HJG ADDCOUNTADDCOUNT:ADD AX,1HJMP INPUTCALL SHOWNUMBEREXIT: RETMAIN ENDPSHOWNUMBER PROC NEARCOVERNUM:DAAMOV DX,AXMOV CL,2HSHOW:ROL DL,4HPUSH DXAND DL,0FHADD DL,30HMOV AH,02HINT 21HPOP DXLOOP SHOWRETSHOWNUMBER ENDPEND START12.有一个首地址为MEM的100D字数组,试编制程序删除数组中所有为零的项,并将后续项向前压缩,最后将数组的剩余部分补上零..model small.386.stack 100Hmem dw12,0,0,0,0,0,1,2,3,6,4,7,8,2,1,0,0,54,5,0,2,4,7,8,0,5,6,2,1,4,8,5,1,45,7 ,5,1,2,0,2,4,0,2,54,0,12,0,0,0,0,0,1,2,3,6,4,7,8,2,1,0,0,54,5,0,2,4,7,8,0,5,6,2,1,4,8,5,1,45,7,5,1, 2,0,2,4,0,2,54,0,45,7,5,1,2,0,2,4,0,2.codeMAIN PROC FARstart:push dsand ax,0push axmov ax,@datamov ds,axmov ax,0Hmov bx,64Hmov cx,64Hmov si,0FFFEHrepeat:ADD si,2Hcmp MEM[si],0HJE callsloop repeatcalls:INC axcall sortcmp ax,1HJE lastValueDEC cxjmp repeatexit :retlastValue:mov mem[bx],0HDEC cxjmp repeatMAIN ENDPsort PROC NEARpush cxpush sisub si,2Hs:add si,2Hmov dx,mem[si]mov mem[si+2],dxloop sreturn:pop sipop cxretsort ENDPEND start13.在STRING到STRING+99单元中存放着一个字符串,试编制一程序测试该字符串中是否存在数字.如有,则把CL的第5位置1,否则将该位置0. DSEG SEGMENTA DW ?B DW ?DSEG ENDSCSEG SEGMENTMAIN PROC FARASSUME CS:CSEG,DS:DSEG START:PUSH DSSUB AX, AXPUSH AXMOV AX, DSEGMOV DS, AXBEGIN:MOV AX, AMOV AX, BXOR AX, BXTEST AX, 0001JZ EXITXCHG BX, AMOV B, BXJMP EXITCLASS:TEST BX, 0001JZ EXITINC BINC AEXIT:RETMAIN ENDPCSEG ENDSEND START14.在首地址为TABLE的数组中按递增次序存放着100H个16位补码数,试编写一个程序把出现次数最多的数及其出现次数分别存放在AX和CX中.DATA SEGMENTTABLE DW 100H DUP (?)MDATA DW ? ; 存放出现次数最多的数COUNT DW 0 ; 存放出现次数DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATASTART:MOV AX,DATAMOV DS,AXMOV BX, 100HMOV DI, 0 ; DI为数组TABLE的指针NEXT:MOV DX, 0MOV SI, 0MOV AX, TABLE[DI]MOV CX, 100HCOMP:CMP TABLE[SI], AXJNE _ADDRINC DX_ADDR:ADD SI, 2LOOP COMPCMP DX, COUNTJLE CHANGMOV COUNT, DXMOV MDATA, AXCHANG:ADD DI, 2DEC BXJNZ NEXTMOV CX, COUNTMOV AX, MDATAMOV AX,4C00HINT 21HCODE ENDSEND START15.数据段中已定义了一个有n个字数据的数组M,试编写一程序求出M 中绝对值最大的数,把它放在数据段的M+2n单元中,并将该数的偏移地址存放在M+2(n+1)单元中.DSEG SEGMENTX DW -4FX DW ?DSEG ENDSCSEG SEGMENTMAIN PROC FARASSUME CS:CSEG,DS:DSEGSTART:PUSH DSPUSH AXMOV AX, DSEGMOV DS, AXBEGIN:CMP X, 5JG A0CMP X, -5JL A0MOV BX,1SUB BX, XMOV FX, BXRETA0:MOV FX, 0RETMAIN ENDPCSEG ENDSEND START16.在首地址为DATA的字数组中,存放了100H个16位补码数,试编写一程序,求出它们的平均值放在AX寄存器中;并求出数组中有多少个数小于此平均值,将结果放在BX寄存器中..MODEL SMALL.STACK 200H.DATADA_TA DW 100H DUP(?).CODE.STARTUPXOR BX,BXXOR DX,DXMOV CX,100HLEA SI,DA_TACYCLE:ADD AX,[SI]ADC DX,0INC SIINC SIDEC CXCMP CX,0JNZ CYCLEMOV CX,100HDIV CX ;计算平均值,存放在AX中.LEA SI,DA_TACOMPARE:CMP AX,[SI]JA NEXT ;计算小于AX的值,其个数存放在BX中INC BXNEXT:INC SIINC SIDEC CXCMP CX,0JNZ COMPARE.EXIT 0END17.试编制一个程序,把AX中的16进制数转化为ASCII码,并将对应的ASCII码依次存放到MEM数组中的四个字节中.例如:当(AX)=2A49H时,程序执行完后,MEM中的4个字节内容为39H,34H,41H,32H.;MODE=DOSDATA SEGMENTSOURCE DW 2A49HMEM DB 4 DUP(?)DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATASTART:MOV AX,DATAMOV DS,AXMOV DX,SOURCELEA BX,MEMMOV CX,4LB:MOV AX,DXAND AX,000FHCMP AL,10JC ADADD AL,7AD:ADD AL,30HMOV [BX],ALINC BXSHR DX,1SHR DX,1SHR DX,1SHR DX,1LOOP LBMOV AH,4CHINT 21HCODE ENDSEND START18.把0-100D之间的30个数存入以GRADE为首地址的30个字数组中,GRADE+i表示学号为i+1的学生成绩.另一个数组RANK为30个学生的名次表,其中RANK+i的内容是学号为i+1的学生的名次.编写一程序,根据GRADE中的学生成绩,将学生名次填入RANK数组中.(提示:一个学生的名次等于成绩高于这个学生的人数加1)DSEG SEGMENTGRADE DW 30 DUP(?)RANK DW 30 DUP(0)DSEG ENDSCSEG SEGMENTMAIN PROC FARASSUME CS:CSEG,DS:DSEGSTART: PUSH DSSUB AX,AXPUSH AXMOV AX,DSEGMOV DS,AXBEGIN:MOV DI,0MOV CX,30LOOP1:PUSH CXMOV CX,30MOV SI,0MOV AX,GRADE[DI]MOV DX,0LOOP2:CMP GRAD[SI],AXJBE GOONINC DXGOON :ADD SI,2LOOP LOOP2POP CXINC DXMOV RANK[DI],DXADD DI,2LOOP LOOP1RETMAIN ENDPCSEG ENDSEND START19.已知数组A包含15个互不相等的整数,数组B包含20个互不相等的整数.试编制一程序,把既在A中又在B中出现的整数存放于数组C中。

新版汇编语言程序设计1-5章【课后答案】

新版汇编语言程序设计1-5章【课后答案】

新版汇编语言程序设计【课后习题答案】第1章汇编语言基础知识〔习题1.1〕简述计算机系统的硬件组成及各部分作用。

〔解答〕CPU:包括运算器、控制器和寄存器组。

运算器执行所有的算术和逻辑运算;控制器负责把指指令逐条从存储器中取出,经译码分析后向机器发出各种控制命令,并正确完成程序所要求的功能;寄存器组为处理单元提供所需要的数据。

存储器:是计算机的记忆部件,它用来存放程序以及程序中所涉及的数据。

外部设备:实现人机交换和机间的通信。

〔习题1.2〕明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB〔解答〕主存又称内存是主存储器的简称,主存储器存放当前正在执行的程序和使用的数据,CPU 可以直接存取,它由半导体存储器芯片构成其成本高、容量小、但速度快。

辅存是辅助存储器的简称,辅存可用来长期保存大量程序和数据,CPU需要通过I/O接口访问,它由磁盘或光盘构成,其成本低、容量大,但速度慢。

RAM是随机存取存储器的英语简写,由于CPU可以从RAM读信息,也可以向RAM写入信息,所以RAM也被称为读写存储器,RAM型半导体存储器可以按地址随机读写,但这类存储器在断电后不能保存信息;而ROM中的信息只能被读出,不能被修改,ROM型半导体通常只能被读出,但这类存储器断电后能保存信息。

存储器由大量存储单元组成。

为了区别每个单元,我们将它们编号,于是,每个存储单元就有了一个存储地址,I/O接口是由一组寄存器组成,为了区别它们,各个寄存器进行了编号,形成I/O地址,通常称做I/O端口。

KB是千字节、MB是兆字节、GB是吉字节和TB是太字节,它们都是表示存储器存储单元的单位。

〔习题1.3〕什么是汇编语言源程序、汇编程序、目标程序?〔解答〕用汇编语言书写的程序就称为汇编语言源程序;完成汇编工作的程序就是汇编程序;由汇编程序编译通过的程序就是目标程序。

〔习题1.4〕汇编语言与高级语言相比有什么优缺点?〔解答〕汇编语言与高级语言相比的优点:由于汇编语言本质就是机器语言,它可以直接地、有效地控制计算机硬件,因而容易产生运行速度快,指令序列短小的高效目标程序,可以直接控制计算机硬件部件,可以编写在“时间”和“空间”两方面最有效的程序。

汇编语言程序设计(第四版)第5章【课后答案】

汇编语言程序设计(第四版)第5章【课后答案】

汇编语言程序设计第四版【课后习题答案】--囮裑為檤第五章高级汇编语言程序设计5.1 条件表达式中逻辑与“&&”表示两者都为真,整个条件才为真,对于程序段:.if (X==5) && (ax!=bx)inc ax.endif请用转移指令实现上述分支结构,并比较汇编程序生成的代码序列。

解:cmp X, 5je abcjmp doneabc: cmp ax, bxjne cdejmp donecde: inc axdone:....5.2条件表达式中逻辑与“||”表示两者之一为真,整个条件就为真,对于程序段:.if (X==5) || (ax!=bx)inc ax.endif请用转移指令实现上述分支结构,并比较汇编程序生成的代码序列。

解:cmp X, 5je abcjmp donecmp ax, bxjne abcjmp doneabc: inc axdone: ....5.3、对于程序段:.while ax!=10mov [bx],axinc bxinc bxinc ax请用处理器指令实现上述循环结构,并比较汇编程序生成的代码序列。

5.4、对于程序段:.repeatmov [bx],axinc bxinc bxinc ax请用处理器指令实现上述循环结构,并比较汇编程序生成的代码序列。

5.5、宏是如何定义、调用和展开的?解:宏定义采用一对伪指令实现,格式如下(其中方括号表示可选):宏名macro [形参表]宏定义体endm宏调用时,利用宏名带上实参即可,格式如下:宏名[实参表]5.6、宏定义中的形式参数有什么特点,它是如何进行形参和实参结合的?解:宏的参数功能非常强大,即可以没有参数,也可以带有一个或多个参数;而且参数的形式非常灵活,可以是常量、变量、存储单元、指令或它们的一部分,还可以是表达式等。

宏展开时的形参与实参结合是用位置匹配的实参对形参进行取代。

实参个数与形参个数不同时,多余的实参没有作用,缺少的实参则用空格代替。

汇编语言 廖建明编 课后习题第五章习题答案

汇编语言 廖建明编 课后习题第五章习题答案

5.1 顺序分支循环5.2 (AX)=5400H (BL)=06H (DX)=2106H5.3 D5.4 C5.5 B5.6 D5.7 C5.8 0FFH 05.9 C5.10 略5.11 B5.12 A5.13 23H 01H 56H 04H 00H5.14 将BUF里的小写字母转换成大写字母5.15 略5.16 (1)完成85274AH与938765H的加法功能(2)不能。

INC对CF无影响,而ADD有影响(3)MOV SI,OFFSET DA TA1(4)置CF为零。

若CF初始为1,则在第一次执行ADC指令时会产生不正确的结果。

5.17(编程题为参考答案,下同)DA TA SEGMENTDA TA1 DB ?DA TA2 DB ?DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN:MOV AX,DA TAMOV DS,AXMOV DX,DA TA1;高位送DXMOV AX,DA TA2;低位送AXSHL AX,1;RCL DX,1;MOV AH,4CHINT 21HCODE ENDSEND BEGIN5.18DA TA SEGMENTDA TAS DB ‘PLEAST INPUT:’,0DH,0AH, ‘$’DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN: MOV AX,DA TAMOV DS,AXMOV AH,9HINT 21H ;输出“PLEASE INPUT:”MOV AH,1INT 21H ;用户输入MOV DL,ALSUB DL,20HMOV AH,2INT 21H ;显示输出MOV AH,4CHINT 21HCODE ENDSEND BEGIN5.19DA TA SEGMENTARRAY DB 20 DUP(?);原数列PLUS DB 20 DUP(0);存放正数NEGA DB 20 DUP(0);存放负数PLUS_N DB 0;指示正数个数NEGA_N DB 0;指示负数个数TIME DB 20DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN: MOV AX,DA TAMOV DS,AXLEA SI,ARRAYLEA BX,PLUSLEA DI,NEGAMOV CX,TIMECLC;以上为初始化LOOP1: MOV AL,[SI]CMP AL,0INC SIJA DAYUJB XIAOLOOP LOOP1;等于零处理JMP SHOWDAYU: MOV [BX],AL;大于零的处理INC BXINC PLUS_NLOOP LOOP1JMP SHOWXIAOYU:MOV [DI],AL;小于零的处理INC DIINC NEGA_NLOOP LOOP1SHOW: MOV DL,PLUS_N;屏幕显示输出MOV AH,2INT 21HMOV DL,NEGA_NMOV AH,2INT 21HMOV AH,4CHINT 21HCODE ENDSEND BEGIN5.20STACK SEGMENT PARA STACKDB 10H DUP(0)STACK ENDSCODE SEGMENTASSUME CS:CODE,SS:STACKBEGIN: PUSHF;标志位入压入栈POP AX;出栈到AXEXCHANGE AH,AL;高低位互换PUSH AX;AX压入栈POPF;弹出到标志寄存器CODE ENDSEND BEGIN5.21DA TA SEGMENTSTR DB ‘INPUT 1 OR 0’,0DH,0AH,‘$’BUFF DB 20 DUP(0)LEN DW 10DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN: MOV AX,DA TAMOV DS,AXMOV DX,OFFSET STRMOV AH,09HINT 21HMOV BH,48;零的ASCII码MOV BL,65;A的ASCII码LEA SI,BUFFMOV CX,LENMOV AH,1HINT 21HCMP DL,1JZ ACMP DL,2JZ BJMP END0;输入非1非2即结束程序A: MOV [SI],BHINC SIMOV [SI],BLINT SIMOV DL,BHMOV AH,2INT 21HMOV DL,BLMOV AH,2INT 21HINC BHINC BLLOOP AJMP END0B: MOV [SI],BLINC SIMOV [SI],BHINC SIMOV DL,BLMOV AH,2INT 21HMOV DL,BHMOV AH,2INT 21 HINC BLINT BHLOOP BEND0: MOV AH,4CHINT 21HCODE ENDSEND BEGIN5.22DA TA SEGMENTX DB ?Y DB ?Z DB ?SUM DB 0DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TA BEGIN: MOV AX,DA TAMOV DS,AXMOV AX,XADD AX,YCMP AX,200MOV AX,XJG SUB0;判断ADD AX,ZJMP END0SUB0: SUB AX,ZEND0: MOV SUM AXMOV AH,4CHINT 21HCODE ENDSEND BEGIN5.23略。

汇编语言程序设计实验指导及习题解答-第五章

汇编语言程序设计实验指导及习题解答-第五章

DW 1,2,3,4,5,6,7,8,9,10 DW($-ARY1)/2 DW ? DW 10,20,30,40,50,60,70,80 DW($-ARY2)/2 DW ? DW 100,200,300,400,500,600 DW($-ARY3)/2 DW ?
;构造数组 1 的地址表
97
;通过寄存器传递地址表的首地址
;通过寄存器传递地址表的首地址 ;求和数组 2 并保存结果 ;构造数组 3 的地址表
MOV TABLE+2,OFFSET COUNT3 MOV TABLE+4,OFFSET SUM3 LEA BX,TABLE CALL ARY-SUM MOV AX, 4C00H INT 21H ARY-SUM PROC NEAR PUSH AX PUSH PUSH PUSH MOV MOV MOV MOV XOR ADD ADD CX SI DI SI,[BX] DI,[BX+2] CX,[DI] DI,[BX+4] AX,AX AX,[SI] SI,2
TRAN
;分离出个位数 ;分离出十位数
MOV ROR MOV MUL ADD
CL,04H AL,CL BH,0AH BH AL,BL
;将十位数移至低 4 位 ;十位数乘以 10 ;乘积与个位数相加
TRAN
POP CX POP BX POPF RET ENDP END START
2.通过地址表传递参数地址 有时直接传递参数本身不能方便地实现所要求功能,需要通过地址表传递参数地址的 方法实现参数传递。具体方法是先建立一个地址表,该表由参数地址构成。然后把表的首 地址通过寄存器或堆栈传递给子程序。 【例 5.4】 计算 ARY1、ARY2、ARY3 三个数组和,并把各自的和分别放入 SUM1、 SUM2、SUM3 单元,其数组元素及结果均为字型数据。 显然数组求和应该用子程序完成,这样做使得代码真正共享。但在子程序中不能直接 引用数组变量名,否则不能做到通用,在这种情况下可以通过传递参数地址的方法实现最 终的参数传递。本例用数组首地址、元素个数的地址、结果地址构成一个地址表,通过寄 存器把表的首地址传递给子程序,子程序通过地址表的参数地址访问到所需参数。
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

5.1 顺序分支循环
5.2 (AX)=5400H (BL)=06H (DX)=2106H
5.3 D
5.4 C
5.5 B
5.6 D
5.7 C
5.8 0FFH 0
5.9 C
5.10 略
5.11 B
5.12 A
5.13 23H 01H 56H 04H 00H
5.14 将BUF里的小写字母转换成大写字母
5.15 略
5.16 (1)完成85274AH与938765H的加法功能
(2)不能。

INC对CF无影响,而ADD有影响
(3)MOV SI,OFFSET DA TA1
(4)置CF为零。

若CF初始为1,则在第一次执行ADC指令时会产生不正确的结果。

5.17(编程题为参考答案,下同)
DA TA SEGMENT
DA TA1 DB ?
DA TA2 DB ?
DA TA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DA TA
BEGIN:MOV AX,DA TA
MOV DS,AX
MOV DX,DA TA1;高位送DX
MOV AX,DA TA2;低位送AX
SHL AX,1;
RCL DX,1;
MOV AH,4CH
INT 21H
CODE ENDS
END BEGIN
5.18
DA TA SEGMENT
DA TAS DB ‘PLEAST INPUT:’,0DH,0AH, ‘$’
DA TA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DA TA
BEGIN: MOV AX,DA TA
MOV DS,AX
MOV AH,9H
INT 21H ;输出“PLEASE INPUT:”
MOV AH,1
INT 21H ;用户输入
MOV DL,AL
SUB DL,20H
MOV AH,2
INT 21H ;显示输出
MOV AH,4CH
INT 21H
CODE ENDS
END BEGIN
5.19
DA TA SEGMENT
ARRAY DB 20 DUP(?);原数列
PLUS DB 20 DUP(0);存放正数
NEGA DB 20 DUP(0);存放负数
PLUS_N DB 0;指示正数个数
NEGA_N DB 0;指示负数个数
TIME DB 20
DA TA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DA TA
BEGIN: MOV AX,DA TA
MOV DS,AX
LEA SI,ARRAY
LEA BX,PLUS
LEA DI,NEGA
MOV CX,TIME
CLC;以上为初始化
LOOP1: MOV AL,[SI]
CMP AL,0
INC SI
JA DAYU
JB XIAO
LOOP LOOP1;等于零处理
JMP SHOW
DAYU: MOV [BX],AL;大于零的处理
INC BX
INC PLUS_N
LOOP LOOP1
JMP SHOW
XIAOYU:MOV [DI],AL;小于零的处理
INC DI
INC NEGA_N
LOOP LOOP1
SHOW: MOV DL,PLUS_N;屏幕显示输出
MOV AH,2
INT 21H
MOV DL,NEGA_N
MOV AH,2
INT 21H
MOV AH,4CH
INT 21H
CODE ENDS
END BEGIN
5.20
STACK SEGMENT PARA STACK
DB 10H DUP(0)
STACK ENDS
CODE SEGMENT
ASSUME CS:CODE,SS:STACK
BEGIN: PUSHF;标志位入压入栈
POP AX;出栈到AX
EXCHANGE AH,AL;高低位互换
PUSH AX;AX压入栈
POPF;弹出到标志寄存器
CODE ENDS
END BEGIN
5.21
DA TA SEGMENT
STR DB ‘INPUT 1 OR 0’,0DH,0AH,‘$’BUFF DB 20 DUP(0)
LEN DW 10
DA TA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DA TA
BEGIN: MOV AX,DA TA
MOV DS,AX
MOV DX,OFFSET STR
MOV AH,09H
INT 21H
MOV BH,48;零的ASCII码
MOV BL,65;A的ASCII码
LEA SI,BUFF
MOV CX,LEN
MOV AH,1H
INT 21H
CMP DL,1
JZ A
CMP DL,2
JZ B
JMP END0;输入非1非2即结束程序A: MOV [SI],BH
INC SI
MOV [SI],BL
INT SI
MOV DL,BH
MOV AH,2
INT 21H
MOV DL,BL
MOV AH,2
INT 21H
INC BH
INC BL
LOOP A
JMP END0
B: MOV [SI],BL
INC SI
MOV [SI],BH
INC SI
MOV DL,BL
MOV AH,2
INT 21H
MOV DL,BH
MOV AH,2
INT 21 H
INC BL
INT BH
LOOP B
END0: MOV AH,4CH
INT 21H
CODE ENDS
END BEGIN
5.22
DA TA SEGMENT
X DB ?
Y DB ?
Z DB ?
SUM DB 0
DA TA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DA TA BEGIN: MOV AX,DA TA
MOV DS,AX
MOV AX,X
ADD AX,Y
CMP AX,200
MOV AX,X
JG SUB0;判断
ADD AX,Z
JMP END0
SUB0: SUB AX,Z
END0: MOV SUM AX
MOV AH,4CH
INT 21H
CODE ENDS
END BEGIN
5.23略。

相关文档
最新文档