assume cs:code
stack segment
dw 8 dup (0)
stack ends
code segment
start:mov ax,stack
mov ss,ax
mov sp,16 设置栈段
mov ax,4240h
mov dx,000fh
mov cx,0ah 举例参数
call divdw
mov ax,4c00h
int 21h
divdw:push bx 保存bx数据入栈
push ax 保存ax数据入栈
mov ax,dx 设置公式int(H/N)*65536的H的ax
mov dx,0 同上 设置公式 H的dx
div cx 公式int(H/N)
mov bx,ax 把商保存入bx
pop ax 出栈,把举例参数ax取出 就是 L
div cx 公式(rem(H/N)*65536+L)/n
mov cx,dx 根据举例要求cx存余数
mov dx,bx 同上,dx存高16位,即 *65536
pop bx 取出bx的数据
ret 返回程序
code ends
end start
书上的div除法运算里 *65536就是*10000H就是高16位存在dx中,加号+就是高位和低位的关系,不是真用加法add,rem(H/N)*65536就是之前int(H/N)的余数在高位,+L就是举例的低位ax。
之前就是因为对div理解的不深,才卡了几天看了论坛的解释做出来的,同学们得好好注意书上的每一个知识要点啊.
- [tolearn] 谢谢你哈…… 10/19 07:10
- [huang425618] 呵呵,第二种方法原来就是第七章的内容,我当时还没学到那呢。我其实不是为我自己辩解,只是我想说,我们的 10/03 20:00
- [qq93324030] 不觉得第二种方法好,他怎么就能那么确定abc三个段是连续的呢?万一不连续他的程序就没作用了。。 10/02 04:37
- [qq93324030] 谢谢,和你对比了我就不用贴了 10/02 00:18