麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > C > 正文

C語言用位運算實現加法運算

2020-02-24 14:38:19
字體:
來源:轉載
供稿:網友

用位運算實現加法也就是計算機用二進制進行運算,32位的CPU只能表示32位內的數,這里先用1位數的加法來進行,在不考慮進位的基礎上,如下


1 + 1 = 0
1 + 0 = 1
0 + 1 = 1
0 + 0 = 0


很明顯這幾個表達式可以用位運算的“^”來代替,如下

?

?


1 ^ 1 = 0
1 ^ 0 = 1
0 ^ 1 = 1
0 ^ 0 = 0


這樣我們就完成了簡單的一位數加法,那么要進行二位的加法,這個方法可行不可行呢?肯定是不行的,矛盾就在于,如何去
獲取進位?要獲取進位我們可以如下思考:

?

?


0 + 0 = 0
1 + 0 = 0
0 + 1 = 0
1 + 1 = 1


//換個角度看就是這樣

?

?


0 & 0 = 不進位
1 & 0 = 不進位
0 & 1 = 不進位
1 & 1 = 進位


正好,在位運算中,我們用“

?

?


//進位可以用如下表示:
(x&y)


到這里,我們基本上擁有了這樣兩個表達式

?

?


x^y //執行加法
(x&y)


我們來做個2位數的加法,在不考慮進位的情況下

?

?


11+01 = 100 // 本來的算法
// 用推算的表達式計算
11 ^ 01 = 10
(11 & 01) //到這里 我們用普通的加法去運算這兩個數的時候就可以得到 10 + 10 = 100
//但是我們不需要加法,所以要想別的方法,如果讓兩個數再按剛才的算法計算一次呢
10 ^ 10 = 00
(10 & 10)


到這里基本上就得出結論了,其實后面的那個 “00” 已經不用再去計算了,因為第一個表達式就已經算出了結果。
繼續推理可以得出三位數的加法只需重復的計算三次得到第一個表達式的值就是計算出來的結果。
c代碼如下:

?

?


int Add(int a,int b)
{
int jw=a&b;
int jg=a^b;
while(jw)
{
int t_a=jg;
int t_b=jw jw=t_a&t_b;
jg=t_a^t_b;
}
return jg;
}


計算機本質是二進制運算,許多高人和天書都展示了如何用位運算來實現讓人糾結卻又驚奇的事情。在豆瓣上看到一篇日志描述如何用位運算實現乘法,其實問題解決的關鍵是如何用位運算實現加法。覺得原文敘述不夠精確,現總結如下。
定理1:設a,b為兩個二進制數,則a+b = a^b + (a&b) 證明:a^b是不考慮進位時加法結果。當二進制位同時為1時,才有進位,因此 (a&b) 定理2:使用定理1可以實現只用位運算進行加法運算。
證明:利用定理1中的等式不停對自身進行迭代。每迭代一次,進位補償右邊就多一位0,因此最多需要加數二進制位長度次迭代,進位補償就變為0,這時運算結束。

以上就是C語言用位運算實現加法運算的全部內容,更多內容請繼續關注武林技術頻道網站!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: h色视频在线观看 | 久久99精品久久久久久青青日本 | 欧美日本日韩 | 欧美国产一级片 | 成人不卡| 视频一区二区三区视频 | 国产亚洲黑人性受xxxx精品 | 爱看久久| 日本一区二区三区视频在线 | 国产羞羞视频在线免费观看 | 中国hdxxxx护士爽在线观看 | 黄色羞羞视频在线观看 | 久久国产秒 | 午夜精品久久久久久毛片 | 欧美激情猛片xxxⅹ大3 | 久久久一区二区精品 | 欧美一级全黄 | 免费在线观看成年人视频 | 亚洲小视频在线 | 13一14毛片免费看 | 国产精品久久久久久久av | 久久91亚洲精品久久91综合 | 久久久一二三 | 国产日产精品久久久久快鸭 | 91av在线免费视频 | 国产流白浆高潮在线观看 | 中午字幕无线码一区2020 | 日韩欧美电影一区二区三区 | 欧美一级黄色免费看 | 欧美囗交 | 久久免费视频3 | 成年免费在线视频 | 天天看成人免费毛片视频 | 久久精品日韩一区 | 国产精品久久久久久久hd | 一道本不卡一区 | 国产精品九九久久一区hh | 一级黄色毛片免费 | 香蕉在线播放 | 午夜精品久久久久久中宇 | av在线免费网址 |