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

简介: ⌚不用加减乘除做加法题目:写一个函数,求两个整数之和,要求在函数体内不得使用"+"、"-"、"*"、"/" 四则运算符号。示例:

⌚不用加减乘除做加法

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

示例:

1. 输入: a = 1, b = 1
2. 输出: 2

提示:

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

📝题解思路1:

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

1. int add(int a, int b){
2. return a + b;
3. }

📝题解思路2:

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

1. #define Add +
2. 
3. int add(int a, int b){
4. return a Add b;
5. }

📝题解思路3:

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

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的值。
}

image.png

⏰不用加号的加法

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

示例:

1. 输入: a = 1, b = 1
2. 输出: 2

提示:

  • a, b 均可能是负数或 0
  • 结果不会溢出 32 位整数📝题解思路1:

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

📝题解思路2:

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

int add(int a, int b)
{
    if(a == 0 && b==0)
        return 0;
    a+=b;
    return a;
}

image.png

⏱两整数之和

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

示例:

1. 输入:a = 1, b = 2
2. 输出:3
3. 并且
4. 输入:a = 2, b = 3
5. 输出:5

提示:

  • -1000 <= a, b <= 1000

📝题解思路

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

int getSum(int a, int b)
{
    while (b) 
    {
          int c = ((unsigned int)a & b) << 1;
          a = a ^ b;
          b = c;
    }
    return a;
}

image.png

⏲递归乘法

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

示例:

输入:A = 1, B = 10
输出:10
并且
输入:A = 3, B = 4
输出:12

提示:

保证乘法范围不会溢出

📝题解思路:

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

一个函数在它的函数体内调用它自身称为递归调用,这种函数称为递归函数。

存在限制条件,当满足这个限制条件之后的时候,递归便会不再继续。

每次递归调用之后都会越来越接近这个限制条件。

这道题你就可以直接使用假定值给它做出来,利用递归特征。

int multiply(int A, int B)
{
    if(B==0)
        return 0;
    return A+multiply(A,B-1);
}

image.png

目录
相关文章
|
10天前
|
索引
【力扣刷题】两数求和、移动零、相交链表、反转链表
【力扣刷题】两数求和、移动零、相交链表、反转链表
18 2
【力扣刷题】两数求和、移动零、相交链表、反转链表
|
10天前
|
算法
"刷题记录:哈希表+双指针 | leetcode-2465. 不同的平均值数目 "
该文段是一篇关于编程题目的解答,主要讨论如何找到数组中所有不同平均值的个数。作者首先使用排序和哈希集来解决,将数组转为列表排序后,通过双指针计算平均值并存入哈希集以去重。然后,作者发现可以优化方案,通过双指针在排序后的数组中直接计算两数之和,用哈希集记录不重复的和,从而避免实际计算平均值,提高了算法效率。最终代码展示了这两种方法。
19 0
|
10天前
|
索引
【力扣刷题】删除链表的倒数第 N 个结点、两两交换链表中的节点、随机链表的复制
【力扣刷题】删除链表的倒数第 N 个结点、两两交换链表中的节点、随机链表的复制
17 0
|
10天前
|
存储 算法 索引
【力扣刷题】只出现一次的数字、多数元素、环形链表 II、两数相加
【力扣刷题】只出现一次的数字、多数元素、环形链表 II、两数相加
22 1
|
10天前
【力扣刷题】二叉树的中序遍历、二叉树的最大深度、翻转二叉树、对称二叉树
【力扣刷题】二叉树的中序遍历、二叉树的最大深度、翻转二叉树、对称二叉树
18 0
|
10天前
|
索引
【力扣刷题】数组实现栈、后缀表达式(逆波兰表达式)求值、中缀表达式转换为后缀表达式(无括号&&有括号)
【力扣刷题】数组实现栈、后缀表达式(逆波兰表达式)求值、中缀表达式转换为后缀表达式(无括号&&有括号)
15 0
|
10天前
|
索引
【力扣刷题】回文链表、环形链表、合并两个有序链表
【力扣刷题】回文链表、环形链表、合并两个有序链表
16 0
|
13天前
|
算法 索引
力扣刷题【第一期】
这是一个关于算法的总结,包含7个不同的问题。1)爬楼梯问题,使用动态规划,通过迭代找到到达n阶楼梯的不同方法数。2)两数之和,通过双重循环找出数组中和为目标值的两个数的索引。3)移动零,使用双指针将数组中的0移到末尾。4)合并有序链表,创建新链表按升序合并两个链表。5)删除链表重复值,遍历链表删除重复元素。6)环形链表检测,使用快慢指针判断链表是否有环。7)相交链表,计算链表长度找
18 1
|
13天前
|
存储 Java
JAVA数据结构刷题 -- 力扣二叉树
JAVA数据结构刷题 -- 力扣二叉树
20 0
|
22天前
|
算法 C++
【刷题】Leetcode 1609.奇偶树
这道题是我目前做过最难的题,虽然没有一遍做出来,但是参考大佬的代码,慢慢啃的感觉的真的很好。刷题继续!!!!!!
15 0