遞歸乘法。 寫一個遞歸函數,不使用 * 運算符, 實現兩個正整數的相乘。可以使用加號、減號、位移,但要吝嗇一些。
- 示例1:
輸入:A = 1, B = 10輸出:10
- 示例2:
輸入:A = 3, B = 4輸出:12
- 提示:
保證乘法范圍不會溢出
class Solution {
public:int multiply(int A, int B) {if (1 == A) {return B;}else if (2 == A) {return B<<1;}else {int temp = A;if (A == (temp>>1)<<1) {return multiply(A>>1,B<<1);}else {return B + multiply(A>>1,B<<1);}}}
};