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;
}
相关推荐
jyan_敬言14 小时前
【算法】高精度算法(加减乘除)
c语言·开发语言·c++·笔记·算法
柒.梧.14 小时前
深入浅出理解原子操作:从单核到多核的实现原理
java
树獭叔叔15 小时前
内存价格被Google打下来了?: TurboQuant对KVCache的量化
算法·aigc·openai
旖-旎15 小时前
前缀和(矩阵区域和)(8)
c++·算法·leetcode·前缀和·动态规划
Moe48815 小时前
Redis 缓存三大经典问题:穿透、击穿与雪崩
java·后端·面试
月落归舟15 小时前
排序算法---(一)
数据结构·算法·排序算法
liuyao_xianhui15 小时前
优选算法_翻转链表_头插法_C++
开发语言·数据结构·c++·算法·leetcode·链表·动态规划
赫瑞15 小时前
Java中的最长公共子序列——LCS
java·开发语言
于先生吖15 小时前
零基础开发国际版同城出行平台 JAVA 顺风车预约系统实战教学
java·开发语言
Book思议-15 小时前
【数据结构实战】循环队列FIFO 特性生成六十甲子(天干地支纪年法),实现传统文化里的 “时间轮回”
数据结构·算法·