LeetCode【69. x 的平方根】

给你一个非负整数 x ,计算并返回 x算术平方根

由于返回类型是整数,结果只保留 整数部分 ,小数部分将被 舍去 。

注意: 不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5

示例 1:

复制代码
输入:x = 4
输出:2

示例 2:

复制代码
输入:x = 8
输出:2
解释:8 的算术平方根是 2.82842..., 由于返回类型是整数,小数部分将被舍去。

提示:

  • 0 <= x <= 231 - 1
java 复制代码
public int mySqrt(int x) {
    if (x == 0) {
        return 0;
    }
    
    int left = 1;
    int right = x;
    int result = 0;
    
    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (mid <= x / mid) {
            left = mid + 1;
            result = mid;
        } else {
            right = mid - 1;
        }
    }
    
    return result;
}
相关推荐
Дерек的学习记录19 分钟前
C++:入门基础(下)
开发语言·数据结构·c++·学习·算法·visualstudio
hzc098765432124 分钟前
Spring Integration + MQTT
java·后端·spring
yugi98783838 分钟前
无线传感器网络中GAF算法节点特性分析
网络·算法
1027lonikitave1 小时前
使用斐波那契数列讲解尾递归
算法
前路不黑暗@1 小时前
Java项目:Java脚手架项目的公共模块的实现(二)
java·开发语言·spring boot·学习·spring cloud·maven·idea
人道领域1 小时前
Spring核心注解全解析
java·开发语言·spring boot
金牌归来发现妻女流落街头2 小时前
日志级别是摆设吗?
java·spring boot·日志
滴滴答滴答答2 小时前
LeetCode Hot100 之 16 合并两个有序链表
算法·leetcode·链表
MOONICK2 小时前
C#基础入门
java·开发语言
ASKED_20193 小时前
企业级大模型微调(Fine-tuning)策略
大数据·人工智能·算法