劍指offer 不用加減乘除做加法及相關思考

2021-10-06 08:31:47 字數 873 閱讀 3014

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

主要考察的是進製轉換的知識點, 也有人用匹配去做,**相當麻煩,暫時不做嘗試。

書上寫到:

其實思路很清晰,一下**就寫出來了。

但我一直有乙個疑問,如果是負數怎麼辦?看了很多牛客答案,都沒有提到要點。

要解釋這個問題,理清楚位運算,以及補碼的知識點尤為重要。

異或操作是對每一位都進行異或(相同為0,不同為1),但需要先把數轉換成補碼才行

原碼和補碼的相互轉換:符號位不變,數值位按位取反,末位再加1

清楚了這兩點,就不會對於負數狀態有太多疑惑了。

public

class

addreturn num1;

}public

static

void

main

(string[

] args)

}

列印結果

temp:-110

num2:101

num1:-1

num2:0

-1

-6和5的異或過程(八位二進位制為例)

-6補碼:1111 1010

5補碼:0000 0101

補碼進行異或:1111 1111

補碼取回原碼:1000 0001

結果為:-1

劍指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...