前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【九日集训】《LeetCode刷题报告》题解内容Ⅰ

【九日集训】《LeetCode刷题报告》题解内容Ⅰ

作者头像
謓泽
发布2022-12-12 14:27:49
2330
发布2022-12-12 14:27:49
举报
文章被收录于专栏:【C】系列
  • 💖 作者简介:大家好,我是泽奀
  • 🏆 全栈领域新星创作者  作者周榜: 67 总排名: 6189 👑 
  • 📝 个人主页:泽奀的博客_CSDN博客
  • 🎉 点赞 ➕ 评论 ➕ 收藏 == 养成习惯😜
  • 📣 系列专栏:九日集训之力扣(LeetCode)算法_泽奀的博客-CSDN博客
  • 💬 总结:希望你看完之后,能对你有所帮助,不足请指正!共同学习交流 🖊
  • 🔉 创作时间:2021 : 12 . 11 日 📅
  • ✉️ 我们并非登上我们所选择的舞台,演出并非我们所选择的剧本。

  • 🎃本章博客题目力扣链接 
  1. 剑指 Offer 65. 不用加减乘除做加法 - 力扣(LeetCode)
  2. 面试题 17.01. 不用加号的加法 - 力扣(LeetCode)
  3. 面试题 08.05. 递归乘法 - 力扣(LeetCode)
  4.  两整数之和 - 力扣(LeetCode)

目录

🎃本章博客题目力扣链接 

⌚不用加减乘除做加法

⏰不用加号的加法

⏱两整数之和 

⏲递归乘法 


⌚不用加减乘除做加法

题目:写一个函数,求两个整数之和,要求在函数体内不得使用"+"、"-"、"*"、"/" 四则运算符号。

示例:

代码语言:javascript
复制
输入: a = 1, b = 1
输出: 2

提示:

  • ab 均可能是负数或 0
  • 结果不会溢出 32 位整数

📝题解思路1:

直接返回值 return a+b;算出两个整数之和多好😜

代码语言:javascript
复制
int add(int a, int b){
    return a + b;
}

📝题解思路2:

既然它说要求在函数体内不能使用四则运算符,那我们直接在函数体外宏定义一个不好吗?  

代码语言:javascript
复制
#define Add +

int add(int a, int b){
    return a Add b;
}

📝题解思路3: 

当然最优质的话,就是使用位运算。其实本题也就是考察你的位运算用的怎么样。

代码语言:javascript
复制
int add(int a, int b)
{
    while(b)
    {
           unsigned int tep = a & b;//a与b赋值tep
           a = a ^ b;      //a 异或 b 赋值给a
           b = tep << 1;   //tep按位左移1位 
    }
    return a;//当表达式b为假,也就是循环为0时候退出,返回值返回整形a的值。
}

⏰不用加号的加法

题目:设计一个函数把两个数字相加。不得使用 + 或者其他算术运算符。

示例:

代码语言:javascript
复制
输入: a = 1, b = 1
输出: 2

提示:

  • ab 均可能是负数或 0
  • 结果不会溢出 32 位整数

📝题解思路1:

还是和上面的题型一样的都,直接参考上面的题即可。

📝题解思路2:

题目说到不让使用 + 法或者是其他算术运算符,那我用赋值运算符总可以了吧。 

代码语言:javascript
复制
int add(int a, int b)
{
    if(a == 0 && b==0)
        return 0;
    a+=b;
    return a;
}

⏱两整数之和 

题目:给你两个整数 a 和 b ,不使用 运算符 + 和 - ,计算并返回两整数之和。

示例:

代码语言:javascript
复制
输入:a = 1, b = 2
输出:3
并且
输入:a = 2, b = 3
输出:5

提示:

  • -1000 <= a, b <= 1000

📝题解思路

和上面两种题解思路都差不多,毕竟题型都是一种类型的。 可以自己带入算下。

代码语言:javascript
复制
int getSum(int a, int b)
{
    while (b) 
    {
          int c = ((unsigned int)a & b) << 1;
          a = a ^ b;
          b = c;
    }
    return a;
}

⏲递归乘法 

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

示例:

代码语言:javascript
复制
输入:A = 1, B = 10
输出:10
并且
输入:A = 3, B = 4
输出:12

提示:

  • 保证乘法范围不会溢出

📝题解思路:

首先,题目中说到了递归我们就要知道递归的特征是什么才行。

  1. 一个函数在它的函数体内调用它自身称为递归调用,这种函数称为递归函数。
  2. 存在限制条件,当满足这个限制条件之后的时候,递归便会不再继续。
  3. 每次递归调用之后都会越来越接近这个限制条件
  • 这道题你就可以直接使用假定值给它做出来,利用递归特征。
代码语言:javascript
复制
int multiply(int A, int B)
{
    if(B==0)
        return 0;
    return A+multiply(A,B-1);
}

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-12-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • ⌚不用加减乘除做加法
  • ⏰不用加号的加法
  • ⏱两整数之和 
  • ⏲递归乘法 
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档