早教吧作业答案频道 -->数学-->
计算机运算乘法首先十进制转二进制就不用讨论了……问下计算机计算乘法的时候如3*3是直接计算3*3还是计算3+3+3?如12*12是12加12次还是12*10+12*2?据说最后还是要转换成0和1二进制(这个……)
题目详情
计算机运算乘法
首先十进制转二进制就不用讨论了……问下计算机计算乘法的时候如3*3是直接计算3*3还是计算3+3+3?如12*12是12加12次还是12*10+12*2?据说最后还是要转换成0和1二进制(这个……)但我就想问下 计算机有没有计算乘法?还是转换成加法计算?
首先十进制转二进制就不用讨论了……问下计算机计算乘法的时候如3*3是直接计算3*3还是计算3+3+3?如12*12是12加12次还是12*10+12*2?据说最后还是要转换成0和1二进制(这个……)但我就想问下 计算机有没有计算乘法?还是转换成加法计算?
▼优质解答
答案和解析
我模拟CPU运算乘法的步骤给你看好了.并不是像楼上的那么算的.假设计算3*3
原码是0011 * 0011(以4位存贮单元,因为是原码,最高位不代表符号位)
CPU中的乘法器过程如下:
3个寄存器分别存放乘数0011 被乘数 0011 一个部分积初始值为0
1,首先判断乘数寄存器(目前为0011)的最低位为1.如果为1则将部分积的值通过加法器加上被乘数0011.因此此步结束后部分积寄存器内容为0011
2,将乘数寄存器右移一位,同时将部分积寄存器也右移一位.同时乘积寄存器最低位溢出丢弃.部分积寄存器高位补0,地位溢出后填充到乘数寄存器.因此.部分积寄存其原来的值0011变成了0001.乘数寄存器0011变成了1001(这里低位的1溢出,最高位被部分积溢出的1填充)
3,判断乘数寄存器最低位(0001).为1.将部分积通过加法器加上被乘数0011.因此此不结束后部分积寄存器内容是(0001+0011=0100).
4,乘数寄存器右移一位,同时将部分积寄存器也有右移一位.同第2步.因此部分积寄存器原来的值0100变成了0010.乘数寄存器1001变成了0100,低位1溢出,最高位被部分积溢出的0填充.
5,判断乘数寄存器低位为0不做加法操作直接做第2步的移位操作.既有了部分积变成0001,乘数变成了0010
6,判断乘数寄存器低位为0不做加法操作直接做第2步的移位操作.既有了部分积变成0000,乘数变成了1001
此时所有乘数全部处理完毕
最终结果将部分积作为高位,乘数寄存器作为低位得到值为00001001 换算成10进制得到9
原码是0011 * 0011(以4位存贮单元,因为是原码,最高位不代表符号位)
CPU中的乘法器过程如下:
3个寄存器分别存放乘数0011 被乘数 0011 一个部分积初始值为0
1,首先判断乘数寄存器(目前为0011)的最低位为1.如果为1则将部分积的值通过加法器加上被乘数0011.因此此步结束后部分积寄存器内容为0011
2,将乘数寄存器右移一位,同时将部分积寄存器也右移一位.同时乘积寄存器最低位溢出丢弃.部分积寄存器高位补0,地位溢出后填充到乘数寄存器.因此.部分积寄存其原来的值0011变成了0001.乘数寄存器0011变成了1001(这里低位的1溢出,最高位被部分积溢出的1填充)
3,判断乘数寄存器最低位(0001).为1.将部分积通过加法器加上被乘数0011.因此此不结束后部分积寄存器内容是(0001+0011=0100).
4,乘数寄存器右移一位,同时将部分积寄存器也有右移一位.同第2步.因此部分积寄存器原来的值0100变成了0010.乘数寄存器1001变成了0100,低位1溢出,最高位被部分积溢出的0填充.
5,判断乘数寄存器低位为0不做加法操作直接做第2步的移位操作.既有了部分积变成0001,乘数变成了0010
6,判断乘数寄存器低位为0不做加法操作直接做第2步的移位操作.既有了部分积变成0000,乘数变成了1001
此时所有乘数全部处理完毕
最终结果将部分积作为高位,乘数寄存器作为低位得到值为00001001 换算成10进制得到9
看了 计算机运算乘法首先十进制转二...的网友还看了以下:
我们已学过的算法有求解一元二次方程的求根公式,加减消元法求二元一次方程组解,二分法求函数零点等.对 2020-05-14 …
用向量算二面角,给出思路即可,不用计算出来.把矩形ABCD沿对角线BD折成二面角A-BD-C,若A 2020-06-27 …
把141人分成三个队,第一队的人数是第二队的人数的一又三分之一倍,第二队的人数是第三队的人数的一又 2020-07-18 …
9/11*3/4-2/11/12/22+2/11*3/4=十二分之五是吧,把这个算式进行简便运算. 2020-07-22 …
急求算赞成率和反对率的方法.想用赋分法.有什么具体的公式没有.我手里的问卷分两部分,第一部分有十一 2020-08-01 …
计算二重积分,(1)计算二重积分∫∫xydσ,其中D是由两条抛物线y=x½,y=x²所围成的闭区间 2020-08-01 …
写出用二分法求方程x^3-x-1=0在区间[1,1.5]上的一个解的算法误差不超过0.001并画出程 2020-12-05 …
1.编写递归算法,计算二叉树中叶子结点的数目?2.写出求二叉树深度的算法,先定义二叉树的抽象数据类型 2021-01-02 …
某工程队修筑一段公路,第一天完成了工程的百分之三十,第二天完成了全工程的百分之二十五,第二天比第一天 2021-01-18 …
计算2*1,2*1/2,2*(-1),2*(-1/2).联系这类具体的数的乘法,你认为一个非0有理数 2021-02-02 …