《汇编语言》王爽——第十章实验10.2 10.3

10.2 解决除法溢出的问题

给出的公式:X/N=int(H/N)*65536+[rem(H/N)*65536+L]/N

参数: ax存放被除数低16 dx存放被除数高16 cx存放除数
分析:

 *65536相当于进到高16位  rem(H/N)*65536不用算,因为算H/N的时候已经把这个结果算出来了,存放在dx,相当于只要计算H/N 和L/H
 

完整代码:

assume cs:code,ss:stack
stack segment
dw 10 dup(0)
stack ends 

code segment
start: 
mov ax,stack
mov ss,ax 
mov sp,20

mov ax,4240h
mov dx,0fh
mov cx,0ah
call divdw 

mov ax,4c00h
int 21h

divdw:

;X/N=int(H/N)*65536+[rem(H/N)*65536+L]/N
;分析 *65536相当于进到高16位  rem(H/N)*65536不用算,因为算h/n的时候已经把这个结果算出来了,存放在dx,相当于只要计算h/n 和l/n
;ax存放被除数低16 dx存放被除数高16 cx存放除数
		push ax 
		
		mov ax,dx ;取出高16位
		
		mov dx,0  ;被除数高16位置0,因为要计算H/N
		
		div cx    ;int()H/N 商结果存放ax,余数结果存放dx,一切都是那么的恰到好处
		
		mov bx,ax ;存放结果
		
		pop ax    ;取出低16位
		
		div cx    ;L/N  商ax 余数dx 
		
		mov cx,dx ;存储余数
		
		mov dx,bx ;存储低16位
			
        ret

code ends 
end start

实验10.3 数值显示

这里要用到前面的子程序showptr(显示以0结尾字符串在显示器上),将数值显示出来。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值