1.原码二位乘法100为什么是源码加2x?
2.汇编语言实现定点原码两位乘法
原码二位乘法100为什么是加2x?
题主断章取义了,书上写:根据“”加2x*。两位这句话是乘运有语境的,这里的源码互赞php源码,前面的两位是乘数的低位(最右),后面的乘运krpano源码0是标志位Cj。
什么是源码Cj呢?根据原码两位乘法的规则就能知道:
当乘数两位状态为时,需要加上3倍被乘数,两位这在计算机中不好直接实现。乘运所以改成加上(4-1)倍被乘数。源码但这么规定后,两位两位乘数最大值只有,乘运也就是源码tigase源码3。所以增加一个标志位Cj,两位当Cj为1时,乘运给两位乘数加上一个“1”。osg 源码
运算时就可以看成:加上“乘数的两位+Cj”倍的被乘数。
再回到:根据“”加2x* 这句话
这里的实际上就是(+0),结果还是activex 源码,所以加2x*。
而Cj何时为0何时为1,看书上原码两位乘的运算规则表就可以了
汇编语言实现定点原码两位乘法
data segment
x db ? ;存放被乘数
y db ? ;存放成数
xb db ? ;存放补码
c db 0
z db 0 ;结果值的正负值
num db ? ;输入数字个数控制
str1 db 'Input x=$'
str2 db 'Input y=$'
str3 db 'Output x*y=$'
str4 db 'Input error,please input again!$'
str5 db '-0.$'
data ends
code segment
assume ds:data,cs:code
main proc far
mov ax,data
mov ds,ax
mov ax,0
mov ah,9 ;输出字符串str1
lea dx,str1
int h
call input ;调用输入子程序,接收被乘数
mov x,bl ;把被乘数放入变量x中
mov dl,bl
neg dl ;对被乘数求补
mov xb,dl ;把补码放入xb变量中
call crlf ;回车换行子程序
mov ah,9
lea dx,str2 ;输出字符串str2
int h
call input ;调用输入子程序,接收乘数
mov y,bl ;把被乘数放入y
;