LeetCode 面试题 08.05. 递归乘法

LeetCode 面试题 08.05. 递归乘法

文章目录

一、题目

递归乘法。 写一个递归函数,不使用 * 运算符, 实现两个正整数的相乘。可以使用加号、减号、位移,但要吝啬一些。

示例1:

输入: A = 1, B = 10
输出: 10

示例2:

输入: A = 3, B = 4
输出: 12

提示:

  • 保证乘法范围不会溢出

二、C# 题解

题目比较简单,直接上答案。

public class Solution {
    public int Multiply(int A, int B) {
        if (A < B) return Multiply(B, A);
        if (B == 0) return 0;
        return Multiply(A, B >> 1) + Multiply(A, B >> 1) + (B % 2 == 0 ? 0 : A);
    }
}
  • 时间:12 ms,击败 94.12% 使用 C# 的用户
  • 内存:25.40 MB,击败 58.82% 使用 C# 的用户