汇编语言 廖建明编 课后习题第五章习题答案
第五章习题答案
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章习题参考答案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
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章汇编语言基础知识〔习题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.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 单元,其数组元素及结果均为字型数据。 显然数组求和应该用子程序完成,这样做使得代码真正共享。但在子程序中不能直接 引用数组变量名,否则不能做到通用,在这种情况下可以通过传递参数地址的方法实现最 终的参数传递。本例用数组首地址、元素个数的地址、结果地址构成一个地址表,通过寄 存器把表的首地址传递给子程序,子程序通过地址表的参数地址访问到所需参数。
第5章汇编语言层习题参考解答-汇编语言与计算机组成原理 答案
.STACK 100H .CODE START: MOV AX, @DATA
MOV DS, AX XOR AH,AH MOV AL,SCORE SUB AL,60 MOV BL,10
L1: L2: L3: L4: L5: NEXT:
DIV BL MOV BL,AL XOR BH,BH SHL BX,1 JMP J_TAB[BX] MOV DX,OFFSET B MOV AH,9 INT 21H JMP NEXT MOV DX,OFFSET BPL MOV AH,9 INT 21H JMP NEXT MOV DX,OFFSET AM MOV AH,9 INT 21H JMP NEXT MOV DX,OFFSET A MOV AH,9 INT 21H JMP NEXT MOV DX,OFFSET AP MOV AH,9 INT 21H JMP NEXT MOV AH, 4CH INT 21H END START
.MODEL SMALL .DATA SCORE BYTE 60 AP BYTE 'A+','$' A BYTE 'A','$' AM BYTE 'A-','$' BPL BYTE 'B+','$' B BYTE 'B','$' J_TAB WORD L1,L2,L3,L4,L5 .CODE START: MOV AX, @DATA
最新汇编语言程序设计(第四版)第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、宏定义中的形式参数有什么特点,它是如何进行形参和实参结合的?解:宏的参数功能非常强大,即可以没有参数,也可以带有一个或多个参数;而且参数的形式非常灵活,可以是常量、变量、存储单元、指令或它们的一部分,还可以是表达式等。
宏展开时的形参与实参结合是用位置匹配的实参对形参进行取代。
实参个数与形参个数不同时,多余的实参没有作用,缺少的实参则用空格代替。
计算机汇编语言第四章第五章答案
本答案经本人简单作答、整理、修改(并是标准答案),仅供同学参考,欢迎同学提出宝贵意见。
4.10给定(BX)=637DH,(SI)=2A9BH,位移量D=7237H,试确定在以下各种寻址方式下的有效地址是什么答案:(1)立即寻址没有 IP的内容(2)直接寻址 7237H ;MOV AX,[7237H](3)使用BX的寄存器寻址没有 ;MOV AX,BX(4)使用BX的间接寻址 637DH ;MOV AX,[BX](5)使用BX的寄存器相对寻址 0D5B4H ;MOV AX,D[BX](6) 基址变址寻址 8E18H ;MOV AX,[BX][SI](7)相对基址变址 004FH ;MOV AX,D[BX][SI]4.11.求执行两条指令后,各标志位的状态MOV AL,91 ;执行后,(AL)=91=5BHADD AL,0BAH加法执行如下:0BA H 1011 1010+ 05B H 0101 1011115 H 1 0001 0101CF:显然最高位产生了进位(两个加数都是两位的,和却有三位),CF=1AF:低四位向高四位产生了进位(A+B产生进位),AF=1ZF:运算结果不为0,ZF=0SF:运算结果最高位为0(高四位:1H=0001B),SF=0OF:负+正=正(两个加数的符号位不同),没有溢出,OF=04-12(1)MOV AL,0F5H 正确(2)ADD [BX][BP],BX 错误,不能同时使用[BX][BP]进行寻址(3)CMP AL,100H 错误,AL为8位,100H大于8位,类型不匹配。
(4)TEST [BP],DL 正确(5)ADC 15,CL 错误,目的操作数不能是立即数(6)SUB [DI],DA_WORD 错误,两个操作数不能同时是存储器操作数。
(7)OR CH,CL 正确(8)MOV AL,1000H 错误,AL为8位,1000H为16位,类型不匹配。
(9)SAR 10H[DI],2 错误,AL为8位,移位多次必须CL中。
最新汇编语言程序设计(第四版)第5章【课后答案】
mov dx,calladdress
endif int 21h
ENDM
5.22; 1.编写主程序,并进行汇编产生OBJ模块;
2.编写独立的子程序,也进行汇编产生OBJ模块;
3.分别编写主程序与子程序时,需要处理好共用变量、过程、逻辑段属性、参 数传递等问题;
4.利用连接程序将主程序模块和子程序模块连接起来,形成完整的可执行程序5.28;;数据段table dw 2277,2138,1808,1709,1522,1356,1208,1139
movstr strN,dstr,sstr
lea si, sstr
lea di, dstr
mov cx, strN
1 pop ax
5.15; wtemp =2 repeat 100 dw 0
dw wtemp wtemp =wtemp+2
endm
5.18; DOS21H MACRO callnum,calladdress mov ah,callnum
5.7、宏结构和子程序在应用中有什么不同,如何选择采用何种结构?
解:宏汇编的特点是在汇编阶段进行语句展开,无需返回,不减少目标程序代 码,执行速度没有改变;通过形参、实参结合传递参数。宏汇编适合于程序段 较短或要求执行速度快的场合。
子程序在执行阶段需要由主程序执行调用指令CALL进行调用,进而转入子
mov [bx],ax
inc bx
inc bx
inc ax
■until ax=10
请用处理器指令实现上述循环结构,并比较汇编程序生成的代码序列。
5.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.1试编写一个汇编语言程序,要求对键盘输入的小写字母用大写字母显示出来。
答:程序段如下:BEGIN:MOV AH,1;从键盘输入一个字符的DOS调用INT21HCMP AL,‘a’;输入字符<‘a’吗?JB STOPCMP AL,‘z’;输入字符>‘z’吗?JA STOPSUB AL,20H;转换为大写字母,用AND AL,11011111B也可MOV DL,AL;显示一个字符的DOS调用MOV AH,2INT21HJMP BEGINSTOP:RET5.2编写程序,从键盘接收一个小写字母,然后找出它的前导字符和后续字符,再按顺序显示这三个字符。
答:程序段如下:BEGIN:MOV AH,1;从键盘输入一个字符的DOS调用INT21HCMP AL,‘a’;输入字符<‘a’吗?JB STOPCMP AL,‘z’;输入字符>‘z’吗?JA STOPDEC AL;得到前导字符MOV DL,AL;准备显示三个字符MOV CX,3DISPLAY:MOV AH,2;显示一个字符的DOS调用INT21HINC DLLOOP DISPLAYSTOP:RET5.3将AX寄存器中的16位数分成4组,每组4位,然后把这四组数分别放在AL、BL、CL 和DL中。
答:程序段如下:DSEG SEGMENTSTORE DB4DUP(?)DSEG ENDS┇BEGIN:MOV CL,4;右移四次MOV CH,4;循环四次LEA BX,STOREA10:MOV DX,AXAND DX,0FH;取AX的低四位MOV[BX],DL;低四位存入STORE中INC BXSHR AX,CL;右移四次DEC CHJNZ A10;循环四次完了码?B10:MOV DL,STORE;四组数分别放在AL、BL、CL和DL中MOV CL,STORE+1MOV BL,STORE+2MOV AL,STORE+3STOP:RET5.4试编写一程序,要求比较两个字符串STRING1和STRING2所含字符是否完全相同,若相同则显示‘MATCH’,若不相同则显示‘NO MATCH’。
汇编语言课后习题5答案
5.1dseg segmentCrLf db 0dh, 0ah, '$' dseg endscseg segmentassume cs:cseg, ds:dseg Start:mov ax, dsegmov ds, axmov ah, 1int 21hpush axlea dx, CrLfmov ah, 9int 21hpop axcmp al, 'a'jb Stopcmp al, 'z'ja Stopsub al, 20hmov dl, almov ah, 2int 21hStop: mov ah, 4chint 21hcseg endsend StartCR equ 0dhLF equ 0ahdseg segmentMsg1 db 'All equal.', CR, LF, '$'Msg2 db 'Only two equal.', CR, LF, '$'Msg3 db 'All three different from each other.', CR, LF, '$'Num1 dw ?; Num1、Num2与Num3为定义的三个16位数Num2 dw ?Num3 dw ?dseg endscseg segmentassume cs:cseg, ds:dsegStart:mov ax, dsegmov ds, axmov ax, Num1cmp ax, Num2je Already_Two_Equalcmp ax, Num3je Two_Equalmov ax, Num2cmp ax, Num3je Two_Equallea dx, Msg3jmp DoneAlready_Two_Equal:cmp ax, Num3je All_EqualTwo_Equal:lea dx, Msg2jmp DoneAll_Equal:lea dx, Msg1Done:mov ah, 9int 21hmov ah, 4chint 21hcseg endsend Start.386dseg segment use16Num dd ?, ?, ? ; 给定的3个32位带符号数dseg endscseg segment use16assume cs:cseg, ds:dsegStart:mov ax, dsegmov ds, axmov ecx, 1mov eax, NumNext: cmp eax, Num[ecx*4]jle Skipxchg eax, Num[ecx*4]mov Num, eaxSkip: inc ecxcmp ecx, 3jne Nextmov eax, Num + 4cmp eax, Num + 8jle Donexchg eax, Num + 8mov Num + 4, eaxDone:mov ah, 4chint 21hcseg endsend Start5.4.386option segment:use16dseg segmentMsg1 db 'Decimal:', '$'Msg2 db 0dh, 0ah,'Binary:', '$'ErrMsg db 0dh, 0ah,'Invalid data.', '$'dseg endscseg segmentassume cs:cseg, ds:dsegStart:mov ax, dsegmov ds, axlea dx, Msg1mov ah, 9int 21hmov ah, 1int 21hmov bl, alcmp bl, '0'jb Errorcmp bl, '9'jbe OkError: lea dx, ErrMsgmov ah, 9int 21hjmp DoneOk: lea dx, Msg2mov ah, 9int 21hshl bl, 4mov cx, 4NextBit:shl bl, 1setc dladd dl, 30hmov ah, 2int 21hloop NextBitDone: mov ah, 4chint 21hcseg endsend Start5.5.386dseg segment use16Data dw 100 dup (?)dseg endscseg segment use16assume cs:cseg, ds:dseg Start:mov ax, dsegmov ds, axmov ax, 0mov ecx, lengthof DataNext: mov bx, Data[ecx*2-2]bt bx, 0jnc Skipcmp ax, 0jz Okcmp ax, bxjbe SkipOk: mov ax, bxSkip: loop NextDone: mov ah, 4chint 21hcseg endsend Start5.6dseg segmentMsg1 db 'Hex:', '$'Msg2 db 0dh, 0ah, 'Bin:', '$' Buf db 5, ?, 5 dup (?) dseg endscseg segmentassume cs:cseg, ds:dseg Start:mov ax, dsegmov ds, axlea dx, Msg1mov ah, 9int 21hlea dx, Bufmov ah, 0ahint 21hlea dx, Msg2mov ah, 9int 21hmov cl, Buf + 1xor ch, chjcxz Exitmov si, 2Next: mov bl, Buf[si]cmp bl, '9'jbe Oksub bl, 7Ok: push cxmov cl, 4shl bl, clmov cx, 4Output: mov dl, '0'shl bl, 1jnc Skipinc dlSkip: mov ah, 2int 21hloop Outputmov dl, 20hmov ah, 2int 21hpop cxinc siloop NextExit: mov ah, 4chint 21hcseg endsend Start5.7.386dseg segment use16Array dw 5 ; 元素个数dw -1, 2, 4, 3, 4 ; 数组元素Max dw -32768Min dw 32767Sum dw 0Average dw 0dseg endscseg segment use16assume cs:cseg, ds:dsegStart:mov ax, dsegmov ds, axxor ecx, ecxmov cx, ArrayNext: mov ax, Array[ecx*2]add Sum, axcmp Max, axjge Skip1mov Max, axSkip1: cmp Min, axjle Skip2mov Min, axSkip2: loop Nextmov ax, Sumcwdidiv Arraymov Average, axDone: mov ah, 4chint 21hcseg endsend Start5.8(1)dseg segmentData1 db 1, 2, 3, 4, 5LEN = $ - Data1Data2 db 1, 2, 4, 3, 5Flag db 0Addr1 dd ?Addr2 dd ?dseg endscseg segmentassume cs:cseg, ds:dseg Start:mov ax, dsegmov ds, axmov si, 0mov cx, LENCompare: mov al, Data1[si]cmp al, Data2[si]jne Differentinc siloop Comparemov Flag, 1jmp DoneDifferent: lea ax, Data1[si]mov word ptr addr1, axmov word ptr addr1 + 2, dseglea ax, Data2[si]mov word ptr addr2, axmov word ptr addr2 + 2, dseg Done: mov ah, 4chint 21hcseg endsend Start(2)dseg segmentData1 db 1, 2, 3, 4, 5LEN = $ - Data1Data2 db 1, 2, 4, 3, 5Flag db 0Addr1 dd ?Addr2 dd ?dseg endscseg segmentassume cs:cseg, ds:dsegStart:mov ax, dsegmov ds, axmov es, axlea si, Data1lea di, Data2mov cx, LENcldrepe cmpsbjne Differentmov Flag, 1jmp DoneDifferent: lea ax, [si-1]mov word ptr addr1, axmov word ptr addr1 + 2, dslea ax, [di-1]mov word ptr addr2, axmov word ptr addr2 + 2, es Done: mov ah, 4chint 21hcseg endsend Start。
汇编语言课后答案第5章
第5章习题5.1 选择题1.条件转移指令能转移的最大范围是(A)A. –128~127B. 0~255C. -32768~32767D. 0~655352.指令JMP BX转移的目标地址的偏移量为(c)A. IP+BX的内容B. IP+[BX]C. BX的内容D. BX所指向的内存字单元的内容3.指令JMP WORD PTR [BX]转移的目标地址偏移量为(D)A. IP+BX的内容B. IP+[BX]C. BX的内容D. BX所指向的内存字单元的内容4.若A、B为无符号数,当A≥B时转移的条件转移指令为(D)A. JGEB. JGC. JAD. JAE5.若A、B为带符号数,当A≤B时转移的条件转移指令为(D)A. JBB. JBEC. JLD. JLE6.下列程序段中,不能转移到标号L1处执行的程序段是(B)A. JMP L1B. MOV BX,L1C. LEA BX,L1D. MOV BX,OFFSET L1 JMP BX JMP BX JMP BX7.下面程序段中,当满足条件,转移到标号L2执行时,BL中的值正确的是( D )CMP BL,2FHJGE L2A. BL=0FFHB. BL=80HC. BL=0D. BL=30H8. 设有下列程序段,若执行后能转移到L3处,则说明AL的内容为( A,D)TEST AL,05HJZ L3A. 0A0HB. 05HC. 第1、3位为0D. 第0、2位为05.2 内存缓冲区BUF1中有10个字节数据,下面的程序段求出这十个数的平均值,并存储于字节变量RESULT中,请将程序补充完整。
MOV AX,0LEA BX,BUF1MOV CX,10LOP1:ADD AX,___[BX]_____INC BX_LOOP LOP1_________MOV DL,10DIV DLMOV RESULT,__AL____HLT5.3 内存缓冲区BUF2中有10个无符号字数据,下面的程序段找出这些数的最大值,并存于MAX字单元。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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略。