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;
}
相关推荐
凌波粒5 分钟前
LeetCode--454.四数相加 II(哈希表)
算法·leetcode·散列表
爱滑雪的码农7 分钟前
Java八:Character 类与string类
java·开发语言
漫随流水12 分钟前
c++编程:D进制的A+B(1022-PAT乙级)
数据结构·c++·算法
tankeven16 分钟前
HJ159 没挡住洪水
c++·算法
美式请加冰22 分钟前
斐波那契数列介绍和使用
算法
APIshop24 分钟前
京东关键词搜索接口完全指南
java·开发语言·数据库
Redemption30 分钟前
嵌软面试每日一阅----Linux驱动之字符设备驱动
linux·面试·职场和发展
东离与糖宝32 分钟前
HashMap从入门到源码:Java7/8/21区别+面试陷阱+高频追问合集
java·人工智能·面试
paeamecium1 小时前
【PAT】 - Course List for Student (25)
数据结构·c++·算法·pat考试
wang09071 小时前
Linux性能优化之CPU利用率
java·linux·运维