亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

請問如何僅使用位移位和加法來進行乘法和除法?

請問如何僅使用位移位和加法來進行乘法和除法?

C
收到一只叮咚 2019-10-16 13:09:42
如何僅使用位移位和加法來進行乘法和除法?如何僅使用位移位和加法來進行乘法和除法?
查看完整描述

3 回答

?
DIEA

TA貢獻1820條經驗 獲得超3個贊

要用加法和平移來乘,您需要將其中一個數分解為2的冪,如下所示:

21 * 5 = 10101_2 * 101_2             (Initial step)
       = 10101_2 * (1 * 2^2  +  0 * 2^1  +  1 * 2^0)
       = 10101_2 * 2^2 + 10101_2 * 2^0 
       = 10101_2 << 2 + 10101_2 << 0 (Decomposed)
       = 10101_2 * 4 + 10101_2 * 1
       = 10101_2 * 5
       = 21 * 5                      (Same as initial expression)

(_2平均基數2)

正如你所看到的,乘法可以被分解成加、移和返回。這也是為什么乘法比位移位或加法更長的原因-在位數中它是O(n^2)而不是O(N)。真正的計算機系統(相對于理論計算機系統)有限的位數,因此乘法比加法和移位要花費恒定的時間倍數。如果我沒記錯的話,現代處理器,如果流水線正確的話,就可以通過干擾處理器中ALU(算術單位)的使用來實現與加法一樣快的乘法。



查看完整回答
反對 回復 2019-10-17
?
青春有我

TA貢獻1784條經驗 獲得超8個贊

x << k == x multiplied by 2 to the power of k
x >> k == x divided by 2 to the power of k

您可以使用這些移位來執行任何乘法操作。例如:

x * 14 == x * 16 - x * 2 == (x << 4) - (x << 1)
x * 12 == x * 8 + x * 4 == (x << 3) + (x << 2)

要將一個數字除以非二次方,我不知道任何簡單的方法,除非您想要實現一些低級邏輯,使用其他二進制操作并使用某種形式的迭代。



查看完整回答
反對 回復 2019-10-17
  • 3 回答
  • 0 關注
  • 505 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號