递归乘法算法

文章目录

欢迎大家阅读我的博客,给生活加点impetus!!

让我们进入《题海探骊》,感受算法之美!!

递归乘法

题目链接

在线OJ

题目详解

这里需要注意保证整数乘法范围不会被溢出

解题思路:

有些人肯定就会直接写出A*B。

c 复制代码
int multiply(int A, int B) {
    return A*B;
}
//或者
int multiply(int A,int B)
{
	if(B==0)
	{
		return 0;
	}
	return A+multiply(A,B-1);
}

但是还有没有不使用乘法的方法呢?

有的,但是这个方法有点吃操作!!

乘法在现实中常见,十进制的乘法都会算,那二进制的乘法利用小学学的方法能不能够计算呢?我们来看一下

假如A=1101(二进制),B=1001(二进制)。

怎么算呢?我们把A*B展开,下来自己去实践一下。

这里直接来讲结论:

对于左移位操作,在二进制中实际是提升阶,比如1<<2=100=4,右移对应降低阶4>>1=10=2,和10进制中乘10和除10的作用一样。

我们来看一下左移和右移的原理

接下来我们就能够将例子这样改写:

代码实现:

c 复制代码
int multiply(int A, int B){
    if(B){//判断b是否为0
        //从0阶(A*(B&1)*2^0)开始,每次算当前阶(A*(B&1)*2^n)的乘法相加,直到B右移完全,即B为0。
        if(B&1){//如果B的最后一位是1
            //B就能够乘A上去,递归算B右移第2位,然后求和+(1*A=A)。
            return multiply(A<<1,B>>1)+A;
        }else{
            //B就不能够乘A上去,递归算B右移第2位,然后求和+(0*A=0)。
            return multiply(A<<1,B>>1);
        }
    }
    // B为0返回0
    return 0;
}

理解:

1:因为这个变量的调整是位移,2倍调整的,时间复杂度是logn

2:<< 1 是将 A 左移一位,相当于 A * 2>> 1 是将 B 右移一位,相当于 B / 2

3:左移一位相当于乘2

4:B&1主要是为了判断这个结尾是否为1 ,判断是否需要加A,递归的时候B右移,就能够取到B的所有位。

5:涉及位移,按位与,三目操作符号等操作,由十进制乘法联想到二进制乘法。

我们最后来看解法代码:

这里我们可以使用三目操作符:

一般形式为condition? expression1 : expression2。其中condition是一个布尔表达式 ,expression1和expression2是两个不同的表达式或值。
当condition为true时,整个表达式的值为expression1的值;当condition为false时,表达式的值为expression2的值。
直接返回return B?multiply(A<<1,B>>1)+(B&1?A:0):0;

结语

感谢大家阅读我的博客,不足之处欢迎指正,希望大家有更好的思路与我交流!!

前日父子万日锛-铁杵磨成针!!加油!!

相关推荐
W23035765733 小时前
经典算法:最长上升子序列(LIS)深度解析 C++ 实现
开发语言·c++·算法
.Ashy.3 小时前
2026.4.11 蓝桥杯软件类C/C++ G组山东省赛 小记
c语言·c++·蓝桥杯
2401_892070984 小时前
链栈(链式栈) 超详细实现(C 语言 + 逐行精讲)
c语言·数据结构·链栈
minji...4 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
语戚5 小时前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·
skywalker_115 小时前
力扣hot100-7(接雨水),8(无重复字符的最长子串)
算法·leetcode·职场和发展
bIo7lyA8v6 小时前
算法稳定性分析中的输入扰动建模的技术9
算法
CoderCodingNo7 小时前
【GESP】C++三级真题 luogu-B4499, [GESP202603 三级] 二进制回文串
数据结构·c++·算法
sinat_286945197 小时前
AI Coding 时代的 TDD:从理念到工程落地
人工智能·深度学习·算法·tdd