题目 递归乘法
写一个递归函数,不使用 * 运算符, 实现两个正整数的相乘。可以使用加号、减号、位移,但要吝啬一些。
示例1:
输入:A = 1, B = 10
输出:10
示例2:
输入:A = 3, B = 4
输出:12
通过对两个数进行位运算,以3*4为例子
按照传统的乘法的累加方式,从左向右判断B的每一位。如果为该位0,则加0;如果为1,则加A,然后左移一位,处理B的下一位。
class Solution {
public:
int multiply(int A, int B) {
//B右移结束,返回并加和
if(B == 0) return 0;
//获取B左边一位的结果
int num = multiply(A , B>>1);
//当前B末尾位为1的话,上个结果左移一位+A
if(B&1 == 1) return (num<<1)+A;
//当前B末尾位为1的话,上个结果左移一位+0
else return num<<1;
}
};