劍指Offer 不用加減乘除做加法

2022-01-28 23:18:44 字數 637 閱讀 8832

寫乙個函式,求兩個整數之和,要求在函式體內不得使用+、-、*、/四則運算符號。

使用位運算,計算機內部就是用閘電路做運算的

^可以看作是 無進製加法

0 ^ 0 = 0

0 ^ 1 = 1

1 ^ 0 = 1

1 ^ 1 = 0

&可以用來計算進製,需要左移一位

0 & 0 = 0

0 & 1 = 0

1 & 0 = 0

1 & 1 = 1

11 + 01 = 100

sum = 11 ^ 01 = 10

carry = (11 & 01) << 1 = 10

// 對sum和carry繼續使用位運算做加法

sum = 10 ^ 10 = 00

carry = (10 & 10) << 1 = 100

// sum為0 已經不用再計算了,最終結果為sum|carry

int add(int num1, int num2)

return sum|carry;

}

劍指offer 不用加減乘除做加法

題目描述 寫乙個函式,求兩個整數之和,要求在函式體內不得使用 四則運算符號。輸入 輸入可能包含多個測試樣例。對於每個測試案例,輸入為兩個整數m和n 1 m,n 1000000 輸出 對應每個測試案例,輸出m n的值。樣例輸入 3 4 7 9樣例輸出 7 16思路 1 先將各bit位相加,不計進製,這...

劍指offer 不用加減乘除做加法

題目描述 寫乙個函式,求兩個整數之和,要求在函式體內不得使用 四則運算符號。思路 本道題用乙個例子講解可能會更為清晰點。現舉5 7 12的例子來說明 1.將兩個數字轉化為二進位制 5 0101 7 0111,將兩個數做異或操作 即相當於加法的不進製操作 5 7 0101 0111 0101 2.計算...

劍指offer 不用加減乘除做加法

題意 寫乙個函式,求兩個整數之和,要求在函式體內不得使用 四則運算符號。分析 之前自己手動yy了一下,直接用二進位制進行位運算,然後沒考慮負數,直接wa,接著仔細分析,數分四種情況 a 0,b 0 a 0,b 0 a 0,b 0 a 0,b 0 然後計算,注意進製或者借位的情況就ok了,比較複雜。c...