当前位置: 首页 > news >正文

面试题08.05.递归算法

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

示例1:

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

示例2:

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

提示:

  1. 保证乘法范围不会溢出

我的答案:

一、信息


- 需要实现一个递归函数来完成两个正整数的乘法。
- 不可以使用`*`运算符。
- 可以使用加号、减号、位移。
- 需要尽可能地减少操作的使用,即要吝啬一些。

二、分析


#### 思考过程中问题的出现:
1. **如何不使用`*`运算符来实现乘法?**
   - 乘法可以看作是多次加法。例如,`3 * 4`可以看作是`4 + 4 + 4`。
   
2. **如何使用递归来实现乘法?**
   - 可以将一个数分解为多个较小的数的和,然后递归地计算这些较小的数的乘积。

3. **如何减少操作的使用?**
   - 可以使用位移操作来实现快速加法和减法。
   - 可以通过减少递归的深度来减少操作的使用。

#### 问题的答案:
1. **乘法的实现**:
   - 通过递归和加法来实现乘法。
   
2. **递归的使用**:
   - 将一个数分解为多个较小的数的和,然后递归地计算这些较小的数的乘积。

3. **减少操作的使用**:
   - 使用位移来实现快速加法和减法。
   - 通过优化递归的实现来减少递归的深度。

#### 思路:
1. **基础思路**:
   - 将乘法`A * B`看作是`A`加自己`B`次,或者`B`加自己`A`次。
   - 使用递归来实现多次加法。

2. **优化思路**:
   - 使用位移操作来实现快速加法和减法。
   - 优化递归的实现,减少递归的深度。

三、步骤(算法流程图)


1. **基准情况**:
   - 如果`A`或`B`中的任何一个为`1`,返回另一个数。
   - 如果`A`或`B`中的任何一个为`0`,返回`0`。

2. **递归步骤**:
   - 将`A`或`B`分解为两个较小的数的和,例如`A = A1 + A2`,`B = B1 + B2`。
   - 递归地计算这些较小的数的乘积,例如`A1 * B1`,`A1 * B2`,`A2 * B1`,`A2 * B2`。
   - 将这些乘积的结果相加,得到最终的乘积。

3. **优化**:
   - 使用位移操作来实现快速加法和减法。
   - 优化递归的实现,例如通过记忆化来避免重复计算。

这个流程图可以用伪代码来表示,如下:

function multiply(A, B):if A == 1:return Bif B == 1:return Aif A == 0 or B == 0:return 0A1, A2 = decompose(A)B1, B2 = decompose(B)product1 = multiply(A1, B1)product2 = multiply(A1, B2)product3 = multiply(A2, B1)product4 = multiply(A2, B2)return product1 + product2 + product3 + product

在实际实现时,可以进一步优化这个算法,例如通过记忆化来避免重复计算,或者通过位移操作来实现快速加法和减法。

四、具体实现

#### C语言实现

#include <stdio.h>int multiply(int A, int B) {if(A == 1) return B;if(B == 1) return A;if(A == 0 || B == 0) return 0;return B + multiply(A - 1, B);
}int main() {printf("%d\n", multiply(1, 10)); // 输出10printf("%d\n", multiply(3, 4)); // 输出12return 0;
}

#### C++语言实现

#include <iostream>class Solution {
public:int multiply(int A, int B) {if(A == 1) return B;if(B == 1) return A;if(A == 0 || B == 0) return 0;return B + multiply(A - 1, B);}
};int main() {Solution solution;std::cout << solution.multiply(1, 10) << std::endl; // 输出10std::cout << solution.multiply(3, 4) << std::endl; // 输出12return 0;
}

#### Java语言实现

public class Solution {public int multiply(int A, int B) {if(A == 1) return B;if(B == 1) return A;if(A == 0 || B == 0) return 0;return B + multiply(A - 1, B);}public static void main(String[] args) {Solution solution = new Solution();System.out.println(solution.multiply(1, 10)); // 输出10System.out.println(solution.multiply(3, 4)); // 输出12}
}

 五、检查错误


在实际编写代码时,需要注意以下几点:
1. **递归终止条件**:确保所有的基准情况都被正确处理,例如`A`或`B`为`1`或`0`的情况。
2. **递归调用**:确保递归调用的参数是正确的,避免无限递归。
3. **返回值**:确保在所有路径上都有返回值。

六、三种语言实现的异同


#### 相同点:
1. **逻辑结构**:三种语言的实现在逻辑结构上是相同的,都是基于递归的方法来实现乘法。
2. **基准情况**:三种语言都需要处理基准情况,即`A`或`B`为`1`或`0`的情况。
3. **递归调用**:三种语言都使用递归调用来实现乘法。

#### 不同点:
1. **语法**:三种语言的语法有所不同,例如函数定义和调用的语法。
2. **输出**:三种语言输出的方式不同,C语言使用`printf`,C++使用`cout`,Java使用`System.out.println`。
3. **类的使用**:在C++和Java中,代码是以类的形式组织的,而在C语言中,代码是以函数的形式组织的。

这些实现都是基于递归的简单实现,可以进一步优化,例如通过记忆化来避免重复计算,或者通过位移操作来实现快速加法和减法。

七、学习收获

1. **递归的应用**:
   - 通过这道题目,我们学习了如何使用递归来解决问题,特别是如何将一个问题分解成更小的子问题,然后递归地解决这些子问题。

2. **基础算法概念**:
   - 我们学习了乘法可以被看作是重复的加法,这是一个基础但重要的概念,帮助我们理解了算法是如何工作的。

3. **编程实践与思维训练**:
   - 编写代码来实现算法使我们得以实际操作来理解递归的工作原理,这对于培养逻辑思维和编程能力都是非常有帮助的。

4. **多语言实现与比较**:
   - 通过在不同的编程语言中实现相同的算法,我们学习了这些语言之间的相似性和差异性,这有助于我们更好地理解和掌握这些语言。

5. **问题分析与解决策略**:
   - 我们学习了如何分析问题,如何在给定的约束条件下寻找解决方案,这对于培养我们的问题解决能力和创新思维都是非常重要的。

6. **优化思维**:
   - 虽然这道题目的基础实现相对简单,但它提供了优化的可能性,例如通过记忆化来避免重复计算,这有助于培养我们的优化思维。

7. **算法的通用性**:
   - 这道题目展示了算法的通用性,即同一算法可以在不同的语言中实现,并且可以应用于不同的问题中。

8. **递归的优化与限制**:
   - 通过实践,我们可以更加深入地理解递归的优势与局限,例如递归可能导致的栈溢出问题,以及如何通过各种策略来优化递归。

### 总结:
这道题目不仅提供了对递归和基础算法概念的实践,还通过多语言实现展示了编程语言的异同,同时也提供了对问题分析、解决策略和优化思维的训练。这些都是计算机科学和编程领域中非常重要的知识和技能。

不熟悉递归的读者你们可以看看我的递归文章传送门7.6 函数的递归调用

相关文章:

面试题08.05.递归算法

递归乘法。 写一个递归函数&#xff0c;不使用 * 运算符&#xff0c; 实现两个正整数的相乘。可以使用加号、减号、位移&#xff0c;但要吝啬一些。 示例1: 输入&#xff1a;A 1, B 10输出&#xff1a;10示例2: 输入&#xff1a;A 3, B 4输出&#xff1a;12提示: 保证乘法…...

分布式IT监控系统

公司的IT系统越来越复杂&#xff0c;对运维和维护服务的需求也越来越高。在这种环境下&#xff0c;分布式IT监控系统应运而生。它逐渐成为公司提高运营效率、保证业务高效运营的关键工具&#xff0c;功能强大&#xff0c;性能优良。 分布式IT监控系统是什么&#xff1f; 分布…...

Redis 是什么?

Redis是一种基于内存的数据库&#xff0c;数据的读写都是在内存中完成的&#xff0c;因此读写速度非常的快&#xff0c;常用于缓存&#xff0c;消息队列&#xff0c;分布式锁等场景。 Redis 在高并发项目中&#xff0c;担任着非常重要的作用&#xff0c;扛高并发的&#xff0c;…...

本地源制作

title: 本地源制作 createTime: 2020-10-29 18:05:52 updateTime: 2020-10-29 18:05:52 categories: linuxyum tags: 制作本地源 通过 createrepo 制作本地源 前提 : 前提制作本地源的机器可以安装 这个软件例如 下载nginx的时候 自己加上 nginx的yum的数据源 &#xff08;rp…...

树莓派(Linux系统通用)交叉编译(环境搭建、简单使用)

概念 交叉编译是指在一台计算机上编译运行在另一台计算机上的程序。&#xff08;编译是指&#xff0c;在一个平台上生成在该平台上的可执行程序&#xff09;通常情况下&#xff0c;编译器和目标平台的架构是不同的&#xff0c;例如&#xff0c;在一台x86平台上编译运行在ARM平…...

uniapp - 微信小程序实现腾讯地图位置标点展示,将指定地点进行标记选点并以一个图片图标展示出来(详细示例源码,一键复制开箱即用)

效果图 在uniapp微信小程序平台端开发,简单快速的实现在地图上进行位置标点功能,使用腾讯地图并进行标点创建和设置(可以自定义标记点的图片)。 你只需要复制代码,改个标记图标和位置即可。...

网络安全--IDS--入侵检测

1. 什么是IDS&#xff1f; IDS---入侵检测是防火墙的一个有力补充&#xff0c;形成防御闭环&#xff0c;可以及时、准确、全面的发现入侵弥补防火墙对应用层检查的缺失。对系统的运行状态进行监视&#xff0c;发现各种攻击企图、过程、结果&#xff0c;来保证系统资源的安全&a…...

js实现数组去重方式(12种方法)

目录 1、filter indexOf2、for object3、for includes4、for splice5、filter indexOf6、Map7、Set8、set Array.from9、sort 排序10、for findIndex11、双重for循环12、reduce 1、filter indexOf 数组去重&#xff1a;利用 filter 过滤 配合 indexOf 查找元素 var a…...

AI智能语音机器人的优势

1.高效自动拨号功能。 导入客户数据&#xff0c;外呼机器人自动拨号&#xff0c;无需看守&#xff0c;真人录音话术&#xff0c;定制场景问答和1秒内的问答响应&#xff0c;为客户带来真实准确的咨询体验。同时&#xff0c;每次通话结束后&#xff0c;外呼系统根据通话时间和关…...

BERT: 面向语言理解的深度双向Transformer预训练

参考视频&#xff1a; BERT 论文逐段精读【论文精读】_哔哩哔哩_bilibili 背景 BERT算是NLP里程碑式工作&#xff01;让语言模型预训练出圈&#xff01; 使用预训练模型做特征表示的时候一般有两类策略&#xff1a; 1. 基于特征 feature based &#xff08;Elmo&#xff09;…...

5-1.(OOP)初步分析MCV架构模式

组成&#xff1a;模型&#xff08;model&#xff09;、视图&#xff08;view&#xff09;、控制器&#xff08;controller&#xff09; view&#xff1a;界面、显示数据 model&#xff1a;数据管理、负责在数据库中存取数据以及数据合法性验证 controller&#xff1a;负责转…...

如何利用React和Flutter构建跨平台移动应用

如何利用React和Flutter构建跨平台移动应用 移动应用已经成为现代生活的一部分&#xff0c;每天都有大量的手机用户在使用各种各样的应用程序。对于开发者来说&#xff0c;构建一个适用于多个平台的移动应用是一个挑战。幸运的是&#xff0c;有一些工具可以帮助我们轻松地实现…...

npm install / webdriver-manager update报错 unable to get local issuer certificate

我这边遇到的问题&#xff0c;用的是angular&#xff0c;跑npm install的时候报错&#xff0c;一开始在.npmrc添加strict-sslfalse但是还是报错&#xff0c;搜索下记录。 参考解决&#xff1a; selenium - webdriver-manager update, Error: unable to get local issuer certi…...

电商项目高级篇-02 elasticsearch-下

电商项目高级篇-02 elasticsearch-下 4.2、QueryDSL返回指定字段 4.2、QueryDSL 返回指定字段 返回单个字段 GET bank/_search {"query": {"match_all": {}}, "sort": [{"balance": {"order": "desc"}}], &quo…...

计算机竞赛 深度学习人体跌倒检测 -yolo 机器视觉 opencv python

0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; **基于深度学习的人体跌倒检测算法研究与实现 ** 该项目较为新颖&#xff0c;适合作为竞赛课题方向&#xff0c;学长非常推荐&#xff01; &#x1f947;学长这里给一个题目综合评分(每项满…...

CloseableHttpClient详解

实现项目中的HttpUtil用到CloseableHttpClient&#xff0c;httpUtil源码&#xff1a;https://download.csdn.net/download/imwucx/88378340 于是学习CloseableHttpClient并记录一下。 一、CloseableHttpClient是什么&#xff1f; CloseableHttpClient实现了AutoCloseable接口和…...

从mysql 5.7 升级到 8.0 的一些注意事项

最近 mysql 5.7 版本将会终止安全更新&#xff0c;越来越多的朋友考虑升级 mysql 8.0&#xff0c;以下是一些刚开始使用时可能存在差异问题的地方&#xff0c;有一些其实在 mysql 5.7 版本里已经开始使用&#xff0c;这里整理一下方便查阅。 1、关于端口&#xff0c;该版本 My…...

喜迎中秋国庆双节,华为云Astro Canvas之我的中秋节设计大屏

目录 前言 前提条件 作品展示 薅羊毛 前言 大屏应用华为云Astro Canvas是华为云低代码平台Astro的子服务之一&#xff0c;是以数据可视化为核心&#xff0c;以屏幕轻松编排&#xff0c;多屏适配可视为基础&#xff0c;用户可通过图形化界面轻松搭建专业水准的数据可视化大屏…...

C++ stoi()函数的用法

stoi()函数的作用 将字符串转为相应进制&#xff0c;可以是8进制&#xff0c;10进制&#xff0c;16进制等&#xff0c;默认的情况下是10进制 stoi源码里面定义 stoi(const string& __str, size_t* __idx 0, int __base 10) 注意&#xff1a;idx 这个可能是版本的问题&…...

Learn Prompt- Midjourney案例:动漫设计

使用 Midjourney 生成动漫有两种方法&#xff1a;使用Niji模式或使用标准的 Midjourney 模型。Niji V5 是 Midjourney 的动漫专用模型。它建立在标准 Midjourney 模型的全新架构之上&#xff0c;更擅长生成命名的动漫角色。Niji V4于2023年12月发布&#xff0c;Niji V5于2023年…...

亚马逊无线鼠标FCC认证办理 FCC ID

无线鼠标是指无线缆直接连接到主机的鼠标&#xff0c;采用无线技术与计算机通信&#xff0c;从而省却电线的束缚。通常采用无线通信方式&#xff0c;包括蓝牙、Wi-Fi (IEEE 802.11)、Infrared (IrDA)、ZigBee (IEEE 802.15.4)等多个无线技术标准。随着人们对办公环境和操作便捷…...

MySQL常见数据类型、特点以及使用场景

以下是一些常见的MySQL数据类型及其特点&#xff0c;包括数据类型的占用字节数、最大存储值和适用场景&#xff1a; 1. 整数类型&#xff1a; TINYINT&#xff1a;1字节&#xff0c;范围从-128到127&#xff08;有符号&#xff09;&#xff0c;0到255&#xff08;无符号&…...

vue markdown显示为html

1、安装依赖markdown-it yarn add markdown-it 2、在页面中引用 import MarkdownIt from markdown-it3、实例化markdown-it const md new MarkdownIt()4、输出 <div class"answer" v-html"md.render(mdTxt)"></div>通过markdown-it可以将m…...

Spring整合RabbitMQ——生产者(利用配置类)

1.生产者配置步骤 2.引入依赖 3.编写配置 配置RabbitMQ的基本信息&#xff0c;用来创建连接工厂的 编写启动类 编写配置类 4. 编写测试类...

Linux基础工具|代码调试工具gdb的使用

1.debug/release gdb是一款Linux下的一款调试器&#xff0c;在没有图形化界面下&#xff0c;是一种不错的调试方案&#xff08;虽然在一般的开发环境中很少会使用gdb&#xff09; 不过要使用gdb&#xff0c;就先要了解debug和release版本。 发布软件的时候有一种叫debug版本…...

Ribbon负载均衡器

两种&#xff1a; 1.1 集中式负载均衡&#xff0c;服务端负载均衡 硬件 nginx 轮询、负载、哈希、随机、权重 为什么要做负载均衡&#xff1f; 1.2 客户端负载均衡器 用客户端 负载均衡器 很多机制可以自定义 小知识&#xff1a;不想让别人调自己&#xff0c;只想用别人的…...

初级软件测试入门教程

一、软件测试的基本概念 1、软件测试的定义 就是以发现错误为目的而运行程序的过程。 软件测试员的目标是找到软件缺陷&#xff0c;尽可能早一些&#xff0c;并确保其得以修复。 2、软件测试方法总体分类 试图验证软件是“工作的”&#xff08;所谓“工作的”就是指软件的…...

4项简化IT服务台任务的ChatGPT功能

近几个月&#xff0c;随着人工智能聊天机器人 ChatGPT 风靡全球&#xff0c;用户可以通过它生成脚本、文章、运动计划表等。同时&#xff0c;这项技术在各行各业都能够进行无穷无尽的应用&#xff0c;在本文中&#xff0c;我们将探讨这项现代技术如何帮助ITSM团队提升服务交付和…...

idea创建同级项目-纠结是SB

idea创建同级项目-纠结是SB 创建方法&#xff1a;...

任正非:天空足够大,世界会越来越兴盛

近日&#xff0c;华为公司创始人任正非与南开大学新闻与传播学院院长、科技日报原总编辑刘亚东今年7月7日在深圳一间咖啡厅的对话最新曝光。 在对话过程中&#xff0c;任正非以“拉法尔喷管”来描述华为的研发体系: “喇叭口”吸收宇宙能量&#xff0c;经过理论研究&#xff0…...