计算机低能儿从0刷leetcode | 29.两数相除 | 倍增法

题目: 29. 两数相除

解答:

本题使用倍增法,这是之前从来没有接触过的方法,chatgpt的介绍是"倍增法的核心思想在于指数增长,即通过成倍增长快速接近目标,能高效地减少原本需要线性处理的计算量,使得原本可能需要多个步骤的计算转化为对数级别的快速操作",在本题中的体现就是每次把除数翻倍,如果翻倍后的结果比被除数小,那么就让倍数(count)也翻倍,否则除数和倍数都不变,直到不能再继续的时候,让被除数中剩下的部分和除数进行相同的操作。主要思路如下:

1、首先进行边界的处理。

2、做除法运算的准备工作,也就是让除数和被除数都变为负数,同时记录下最终结果的符号,这是因为负数的范围最小可以取到-2147483648,如果用正数处理,最大只能取到2147483647。而因为负数的转换,在代码实现中的逻辑与前文描述略有不同,也就是翻倍后的结果要比除数大时才可以让倍数翻倍。

3、核心函数为div函数,用来进行倍增操作。将每次调用倍增函数的结果累加起来,就是最后商的数值。此处需要注意,while语句中的条件如果写作while(tmp+tmp>=a)或者while(2*tmp>=a)都会溢出,比如-1610612736 + -1610612736的时候,因此我们写为 while(tmp-a+tmp>=0)就可以避免这种情况。

以下为代码实现:

复制代码
class Solution {
public:
    int divide(int dividend, int divisor) {
        int res=0;int flag=1;
        if(dividend==2147483647&&divisor==1) return 2147483647;
        if(dividend==-2147483648&&divisor==-1) return 2147483647;
        if(dividend==-2147483648&&divisor==1) return -2147483648;

        if(dividend>0) {flag=-flag; dividend = -dividend;}
        if(divisor>0) {flag=-flag; divisor=-divisor;}
        
        res = div(dividend,divisor);
        res=res*flag;

        return res;
    }

    int div(int a,int b){
        if(a>b)  return 0;
        int count=1;
        int tmp=b;
        while(tmp-a+tmp>=0){
            tmp=tmp*2;
            count=count*2;
        }

        count=count+div(a-tmp,b);
        return count;
    }
};
相关推荐
蒹葭玉树2 分钟前
【C++上岸】C++常见面试题目--操作系统篇(第二十八期)
linux·c++·面试
醉颜凉2 分钟前
【LeetCode】打家劫舍III
c语言·算法·leetcode·树 深度优先搜索·动态规划 二叉树
达文汐5 分钟前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗5 分钟前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
User_芊芊君子5 分钟前
【LeetCode经典题解】搞定二叉树最近公共祖先:递归法+栈存路径法,附代码实现
算法·leetcode·职场和发展
培风图南以星河揽胜6 分钟前
Java版LeetCode热题100之零钱兑换:动态规划经典问题深度解析
java·leetcode·动态规划
算法_小学生7 分钟前
LeetCode 热题 100(分享最简单易懂的Python代码!)
python·算法·leetcode
执着2597 分钟前
力扣hot100 - 234、回文链表
算法·leetcode·链表
Gorgous—l9 分钟前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法
熬夜造bug9 分钟前
LeetCode Hot100 刷题路线(Python版)
算法·leetcode·职场和发展