汇编语言实验十第1、2题答案
本帖最后由 s0512 于 2013-5-25 15:32 编辑我做出来了,但感觉效率似乎不高,所以找答案,甲鱼哥的站貌似没有实验十的答案,,因此求助广大鱼油~~{:1_1:}
本帖最后由 lukelqz 于 2012-8-12 10:54 编辑
第一题:我的代码,也没怎么优化,随便写的。{:5_91:} ;名称:show_str
;功能:在指定的位置,用指定的颜色,显示一个用0结束的字符串
;参数:(dh)=行号(取值范围0-24),(dl)=列号(取值范围0-79)
; (cl)=颜色,ds:si指向字符串的首地址
;返回: 无
show_str:
push es
push ax
push bx
push cx
push dx
push si
push di
mov ax,0b800h
mov es,ax
mov si,0
mov al,0a0h
mov ah,0
mul dh
mov bx,ax
add dl,dl
mov dh,0
add bx,dx
mov di,0
mov ah,cl
str0: mov cl,
mov ch,0
jcxz ok
mov al,cl
mov es:,ax
inc si
add di,2
jmp short str0
ok: pop di
pop si
pop dx
pop cx
pop bx
pop ax
pop es
ret第二题: ;名称:divdw
;功能:进行不会产生溢出的除非运算,被除数为dword型,除数为word型,结果为dword型
;参数:(ax)=dword型数据的低16位
; (dx)=dword型数据的高16位
; (cx)=除数
;返回:(dx)=结果的高16位,(ax)=结果的低16位
; (cx)=余数
divdw: push si
push ax
mov ax,dx
mov dx,0
div cx
mov si,ax
pop ax
div cx
mov cx,dx
mov dx,si
pop si
ret 本帖最后由 张国祥 于 2012-8-13 00:08 编辑
lukelqz 发表于 2012-8-12 10:53 static/image/common/back.gif
第一题:我的代码,也没怎么优化,随便写的。 第二题:
@lukelqz,这个@ 管用不……,,我想问一下,你的第二题,,是按照书上提供的公式来算的吗? lukelqz 发表于 2012-8-12 10:53 static/image/common/back.gif
第一题:我的代码,也没怎么优化,随便写的。 第二题:
我的第一题:
show_str:
mov ax,0b800h
mov es,ax
mov bl,cl
call adress
s:
xor ch,ch
mov cl,
jcxz ok
mov al,
mov ah,bl
mov es:,ax
add di,2
inc si
jmp short s
adress:
xor ah,ah
mov al,160
dec dh
mul byte ptr dh
mov di,ax
xor ah,ah
mov al,2
dec dl
mul byte ptr dl
add di,ax
ret
ok: ret
lukelqz 发表于 2012-8-12 10:53 static/image/common/back.gif
第一题:我的代码,也没怎么优化,随便写的。 第二题:
原公式:X/N=int(H/N)*65536+/N
65536=10000H,无法用一个寄存器存下他,我就想到256*256=65536,所以连乘两次即可。
当时想问题时感觉即使使用栈也有困难,要存储的数据超过4个,寄存器出入栈顺序分配不过来,于是先从后半部分(/N)下手,这样寄存器够了,出入栈顺序也妥当,,问题最终解决了,,but,看到答案后,,我震惊了,,,,完全不需要我这么麻烦,,,问题似乎在于你们忽略了65536的存在……
我的源码:
divdw:
push ax
mov ax,dx
xor dx,dx
div cx
pop bx
push ax
push bx
mov ax,dx
mov bx,256
mul word ptr bx
mul word ptr bx
pop bx
add ax,bx
div cx
mov cx,dx
pop dx
push ax
mov ax,dx
mov bx,256
mul word ptr bx
mul word ptr bx
pop bx
add ax,bx
ret
张国祥 发表于 2012-8-13 00:09 static/image/common/back.gif
原公式:X/N=int(H/N)*65536+/N
65536=10000H,无法用一个寄存器存下他,我就想到2 ...
10000H就是左移4位啊。呵呵。这题有技巧的。我开始做的也很麻烦。不过小甲鱼的视频中有提示的。 张国祥 发表于 2012-8-12 18:17 static/image/common/back.gif
我的第一题:
建议你把子程序中用到的寄存器压栈,要不然调用的时候,会出问题的哦。特别是课程设计一的时候。 lukelqz 发表于 2012-8-13 09:24 static/image/common/back.gif
10000H就是左移4位啊。呵呵。这题有技巧的。我开始做的也很麻烦。不过小甲鱼的视频中有提示的。
原来如此,我没有很好地利用65536的特点 lukelqz 发表于 2012-8-13 09:24 static/image/common/back.gif
10000H就是左移4位啊。呵呵。这题有技巧的。我开始做的也很麻烦。不过小甲鱼的视频中有提示的。
你的书是不是第一版的?怎么有si? divdw:
push ax
mov ax,dx
xor dx,dx
div cx
mov bx,ax
pop ax
div cx
mov cx,dx
mov dx,bx
ret lukelqz 发表于 2012-8-13 09:27 static/image/common/back.gif
建议你把子程序中用到的寄存器压栈,要不然调用的时候,会出问题的哦。特别是课程设计一的时候。
的确,子程序调用时最好先压栈,,不过我觉得这题,,似乎没必要 张国祥 发表于 2012-8-13 22:22 static/image/common/back.gif
的确,子程序调用时最好先压栈,,不过我觉得这题,,似乎没必要
我开始觉得没必要,后来写课程设计一就感觉很有必要了。主程序用到很多寄存器,子程序又来用,很容易出错 张国祥 发表于 2012-8-13 22:20 static/image/common/back.gif
你的书是不是第一版的?怎么有si?
一样的,你用的是bx,我用的是si。都可以。你用bx没有压栈而已。 我也正在努力的学习那一章节 狼翌北辰 发表于 2013-3-19 15:46 static/image/common/back.gif
我也正在努力的学习那一章节
:D加油学习!~
页:
[1]