a + b 的问题拆分为 (a 和 b 的无进位结果) + (a 和 b 的进位结果)
1. 无进位加法使用异或运算计算得出
2. 进位结果使用与运算和移位运算计算得出
3. 循环此过程,直到进位为 0
class Solution { public int getSum(int a, int b) { while(b != 0){ //进位为 0 停止循环 int temp = a ^ b; // 无进位加法使用异或运算计算得出 b = (a & b) << 1; //进位结果使用与运算和移位运算计算得出 a = temp; } return a; } }