【九日集训】《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

目录
相关文章
|
4月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
68 6
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 26. 树的子结构
这篇文章提供了解决LeetCode上"剑指Offer 26. 树的子结构"问题的Python代码实现和解析,判断一棵树B是否是另一棵树A的子结构。
65 4
|
5月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
136 2
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
280页PDF,全方位评估OpenAI o1,Leetcode刷题准确率竟这么高
【10月更文挑战第24天】近年来,OpenAI的o1模型在大型语言模型(LLMs)中脱颖而出,展现出卓越的推理能力和知识整合能力。基于Transformer架构,o1模型采用了链式思维和强化学习等先进技术,显著提升了其在编程竞赛、医学影像报告生成、数学问题解决、自然语言推理和芯片设计等领域的表现。本文将全面评估o1模型的性能及其对AI研究和应用的潜在影响。
69 1
|
4月前
|
数据采集 负载均衡 安全
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
本文提供了多个多线程编程问题的解决方案,包括设计有限阻塞队列、多线程网页爬虫、红绿灯路口等,每个问题都给出了至少一种实现方法,涵盖了互斥锁、条件变量、信号量等线程同步机制的使用。
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
|
5月前
|
索引 Python
【Leetcode刷题Python】从列表list中创建一颗二叉树
本文介绍了如何使用Python递归函数从列表中创建二叉树,其中每个节点的左右子节点索引分别是当前节点索引的2倍加1和2倍加2。
82 7
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 22. 链表中倒数第k个节点
Leetcode题目"剑指 Offer 22. 链表中倒数第k个节点"的Python解决方案,使用双指针法找到并返回链表中倒数第k个节点。
62 5
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 30. 包含min函数的栈
本文提供了实现一个包含min函数的栈的Python代码,确保min、push和pop操作的时间复杂度为O(1)。
39 4
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 21. 调整数组顺序使奇数位于偶数前面
Leetcode题目"剑指 Offer 21. 调整数组顺序使奇数位于偶数前面"的两种Python解决方案,一种是使用双端队列调整数组顺序,另一种是使用双指针法将奇数移到数组前半部分,偶数移到后半部分。
33 4