LCR 001. 两数相除

文章目录

题意

题目链接

思路

注意边界判断

代码

C++ 复制代码
class Solution {
public:
    int divide(int a, int b) {
        if (a == INT_MIN && b == -1)
            return INT_MAX;
        int flag = false;
        if (a >= 0 && b >= 0 ||
            a <= 0 && b <= 0)
            flag = true;
        int ans = 0;
        a = -abs(a);
        b = abs(b);
        if (b == 1)
            return flag ? -a : a;
        if (abs(a) == abs(b))
            return flag ? 1 : -1;
        while (a + b <= 0)
        {
            int i = 0;
            while (a + (b << i) < 0 && INT_MAX - (b << i) > (b << i))
                i++;
            if (i)
                i--;
            a += (b << i);
            ans += 1 << i;
        }
        return flag ? ans : -ans;
    }
};
相关推荐
Chase_______13 小时前
LeetCode 1493 & 3634 题解:滑动窗口双指针,从“删一个元素的全1子数组“到“最少移除使数组平衡“
算法·leetcode
悲伤小伞13 小时前
LeetCode 热题 100_4-283. 移动零
算法·leetcode·职场和发展
星 海14 小时前
网络芯片对IP地址最长前缀匹配算法的实现
网络·算法
OYangxf14 小时前
力扣hot100【滑动窗口】
算法·leetcode·职场和发展
CQU_JIAKE14 小时前
5.7【A】
算法
2zcode14 小时前
基于SVM与HOG算法的行人检测系统设计与实现
算法·机器学习·支持向量机
MATLAB代码顾问14 小时前
MATLAB实现粒子群算法优化PID参数
开发语言·算法·matlab
翎沣14 小时前
C++11异常处理机制
java·c++·算法
火花怪怪14 小时前
Origin分析外量子效率(EQE, External Quantum Efficiency)数据处理-EQE计算带隙
算法·数据分析
上弦月-编程14 小时前
异或法巧解数组中两独数
数据结构·算法