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;
    }
};
相关推荐
SimpleLearingAI13 分钟前
大模型推理框架总结解析
算法
Σίσυφος190018 分钟前
正则化数据并校准数据
人工智能·算法·机器学习
HZ·湘怡21 分钟前
基于动态数组的栈(顺序栈)01
数据结构·算法
Chen_harmony22 分钟前
十八、C语言内存函数
c语言·算法
__Coffee__40 分钟前
封装矩阵结构体
线性代数·算法·矩阵
变量未定义~1 小时前
字符串哈希匹配字符串
数据结构·算法·哈希算法
周末也要写八哥1 小时前
浅谈二叉树的深度优先搜索(DFS)算法
算法·深度优先
天真小巫1 小时前
2026.5.17总结
职场和发展
凯瑟琳.奥古斯特1 小时前
信号分类与特性解析
java·开发语言·职场和发展
y = xⁿ1 小时前
20天速通LeetCodeday17:一维动态规划
算法