这是我以前写的,不是很好,但是可以运行的.
呵呵,我也是这个学期才学的
;说明该程序的功能的实现一位数(1~9)的+,-,*,/,的运算,只能输入1~9,+,-,*,/,等字符.
;按回车键可以继续输入
.MODEL SMALL
.STACK
.DATA
ff DB '`````` ',?,'$'
AA DB ?,?,?,'=',?,' ',?,'$'
BB DB 'input error!,please reinput!$'
CC DB 0dh,0ah,' ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^'
DB 0dh,0ah,' ^ input q to exit ^'
db 0dh,0ah,' ^ input enter go on input ^'
db 0DH,0AH,'*************^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^********************************$'
.CODE
.STARTUP
MAIN PROC
push dx
mov ah,09h
mov dx,word ptr offset cc
int 21h
call new
pop dx
HAND: MOV AH,01H ;输入第一个数字
INT 21H
CMP AL,'q'
JZ EXIT2
CMP AL,'1' ;判断输入的数字是否是1~9,若不是输出错误信息
JL ERROR
CMP AL,'9'
JG ERROR
MOV DL,AL ;把数字放到[AA]处
MOV [AA],DL
MOV AH,01H ;输入运算符,并判断是否是+,-,*,/
INT 21H
CMP AL,'q'
JZ EXIT2
CMP AL,'-'
JZ OK
CMP AL,'+'
JZ OK
CMP AL,'*'
JZ OK
CMP AL,'/'
JZ OK
JMP ERROR ;如果输入的不是+,-,*,/,输出错误信息
OK: MOV CL,AL ;输入第二个数
MOV [AA+1],AL
MOV AH,01H
INT 21H
CMP AL,'q'
JZ EXIT2
CMP AL,'1'
JL ERROR
CMP AL,'9'
JG ERROR
MOV BL,AL
MOV [AA+2],BL
CALL NEW
CMP CL,'+' ;判断是执行哪一个运算
JZ NEXT1
CMP CL,'-'
JZ NEXT2
CMP CL,'*'
JZ NEXT3
CMP CL,'/'
JZ NEXT4
NEXT1: CALL ADD1 ;调用加法运算
push ax ;判断是否继续输入,如果是按ENTER键继续输入,不
MOV AH,08H ;是按其他键
INT 21H
call new
CMP AL,0DH
JZ HAND
cmp al,'q'
jz EXIT2
pop ax
JMP EXIT1
NEXT2: CALL SUB1
push ax ;判断是否继续输入,如果是按ENTER键继续输入,不
MOV AH,08H ;是按其他键
INT 21H
call new
CMP AL,0DH
JZ HAND
cmp al,'q'
jz EXIT2
pop ax
JMP EXIT1
NEXT3: CALL MUL1
push ax ;判断是否继续输入,如果是按ENTER键继续输入,不
MOV AH,08H ;是按其他键
INT 21H
call new
CMP AL,0DH
JZ HAND
cmp al,'q'
jz EXIT2
pop ax
JMP EXIT1
NEXT4: CALL DIV1
push ax ;判断是否继续输入,如果是按ENTER键继续输入,不
MOV AH,08H ;是按其他键
INT 21H
call new
CMP AL,0DH
JZ HAND
cmp al,'q'
jz EXIT2
pop ax
JMP EXIT1
ERROR: push ax ;输出错误的信息
push dx
MOV AH,09H
CALL NEW
MOV DX,WORD PTR OFFSET BB
INT 21H
pop dx
pop ax
call new
JMP HAND
EXIT1: MOV AH,08H
INT 21H
cmp al,'q'
JMP HAND
EXIT2: .EXIT 0
MAIN ENDP
;换行的子程序
new proc
PUSH AX
PUSH DX
mov dl,0dh
mov ah,2
int 21h
mov dl,0ah
mov ah,2
int 21h
POP DX
POP AX
ret
new endp
ADD1 PROC ;实现加法子程序
PUSH AX
PUSH BX
PUSH DX
MOV AL,DL
AND AX,000FH
AND BX,000FH
ADD AL,BL
MOV BL,0AH
DIV BL
OR AH,30H
OR AL,30H
MOV WORD PTR [AA+4],AX
MOV DX,OFFSET AA
MOV AH,09H
INT 21H
POP DX
POP BX
POP AX
RET
ADD1 ENDP
SUB1 PROC ;实现减法子程序
PUSH AX
PUSH BX
PUSH DX
MOV AL,DL
AND AX,000FH
AND BX,000FH
cmp al,bl ;判断AL,BL的大小,若AL>BL,跳到CCC
jg CCC
mov al,bl
mov bl,dl
and bl,0fh
SUB AL,BL
MOV BL,0AH
DIV BL
MOV AL,2DH
OR AH,30H
JMP EEE
CCC: SUB AL,BL
MOV BL,0AH
DIV BL
OR AH,30H
OR AL,30H
EEE: MOV WORD PTR [AA+4],AX
MOV DX,OFFSET AA
MOV AH,09H
INT 21H
POP DX
POP BX
POP AX
RET
SUB1 ENDP
MUL1 PROC ;实现乘法子程序
PUSH AX
PUSH BX
PUSH DX
MOV AL,DL
AND AX,000FH
AND BX,000FH
MUL BL
MOV BL,0AH
DIV BL
OR AH,30H
OR AL,30H
MOV WORD PTR [AA+4],AX
MOV DX,OFFSET AA
MOV AH,09H
INT 21H
POP DX
POP BX
POP AX
RET
MUL1 ENDP
DIV1 PROC ;实现除法子程序
PUSH AX
PUSH BX
PUSH CX
PUSH DX
MOV AL,DL
AND AX,000FH
AND BX,000FH
DIV BL
OR AH,30H
MOV CL,AH
XOR AH,AH
OR AL,30H
MOV WORD PTR [AA+4],AX
MOV DX,OFFSET AA
MOV AH,09H
INT 21H
cmp cl,'0'
jz ssss
push dx
MOV [ff+7],cl
mov dx,offset ff
INT 21H
pop dx
ssss: POP DX
POP CX
POP BX
POP AX
RET
DIV1 ENDP
END
上学期弄过一个,希望LZ能明白原理
.model small
.386
data segment
buff1 db 10 dup(0) ;存放第一个数
buff2 db 10 dup(0) ;存放第二个数
len db 0ah ;操作数10
k word 0 ;结果数组中的下标
ones db 0 ;个位数
tens db 0 ;十位数
hint1 db 0ah,0dh,0ah,0dh,'Please input the first number(10 bits):','$'
hint2 db 0ah,0dh,0ah,0dh,'Please input the second number(10 bits):','$'
hint3 db 0ah,0dh,0ah,0dh,'The result is:','$'
data ends
extra segment
db 20 dup(0) ;存放结果
extra ends
code segment use16
assume cs:code,ds:data,es:extra
start:
mov ax,data
mov ds,ax
mov ax,extra
mov es,ax
mov dx,offset hint1 ;输出提示信息
mov ah,09h
int 21h
xor si,si
readnum1: ;读入十个数
xor al,al
mov ah,01h
int 21h
sub al,30h
mov buff1[si],al ;存放在buff1中
inc si
cmp si,09h
jbe readnum1 ;未满十个,继续读入
mov dx,offset hint2 ;输出提示信息
mov ah,09h
int 21h
xor si,si
readnum2: ;读入十个数
xor al,al
mov ah,01h
int 21h
sub al,30h
mov buff2[si],al ;存放在buff2中
inc si
cmp si,09h
jbe readnum2 ;未满十个,继续读入
xor cx,cx
xor bx,bx
xor ax,ax
xor dx,dx
mov si,0ah ;外循环
next1:
mov di,0ah ;内循环
next2:
mov al,buff1[si-1]
mov bl,buff2[di-1]
mul bl
div len
mov tens,al ;取商
mov ones,ah ;取余
mov k,0
add k,si
add k,di ;k=di+si
mov bp,k
mov ah,ones
add es:[bp],ah ;放入个位
cmp byte ptr es:[bp],0ah
jnge here1 ;小于10则跳到here1
xor ax,ax
mov al,es:[bp]
div len
mov es:[bp],ah
add byte ptr es:[bp-1],01h
here1:
mov al,tens
add es:[bp-1],al
;这段可以不要,因为进位最多不超过1位(9*9=81)
;cmp byte ptr es:[bp-1],0ah
;jnge here2 ;小于10则跳到here2
;xor ax,ax
;mov al,es:[bp-1]
;div len
;mov byte ptr es:[bp-1],00h
;mov es:[bp-1],ah
;add byte ptr es:[bp-2],01h
here2:
dec di
cmp di,0
ja next2 ;内循环
dec si
cmp si,0
ja next1 ;外循环
mov dx,offset hint3 ;输出提示信息
mov ah,09h
int 21h
xor si,si
mov si,01h ;0单元没用
print: ;输出结果
xor dl,dl
mov dl,es:[si]
add dl,30h
mov ah,02h
int 21h
inc si
cmp si,20
jbe print
exit:
mov ax,4c00h
int 21h
code ends
end start