69. x 的平方根


文章目录


1.题目

69. x 的平方根

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

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

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

示例 1:

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

示例 2:

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

2.思路

  1. 初始化左边界 left 为 0,右边界 rightx,用于定义搜索范围。
  2. 通过二分查找的方式,计算中间值 mid,并求出 mid 的平方 square
  3. 如果 square 等于 x,直接返回 mid,因为它就是 x 的整数平方根。
  4. 如果 square 大于 x,说明当前的 mid 太大,更新右边界 right = mid - 1,继续在较小的范围内搜索。
  5. 如果 square 小于 x,说明当前的 mid 太小,更新左边界 left = mid + 1,继续在较大的范围内搜索。
  6. 当搜索结束时,返回 right,它是平方小于或等于 x 的最大整数,即 x 的整数平方根。

3.代码

c++ 复制代码
class Solution {
public:
    int mySqrt(int x) {
        long long  left = 0, right = x;
        while(left<=right){
            long long mid = left+(right-left)/2;
            long long square  = mid*mid;
            if(square == x){
                return mid;
            }else if(square>x){
                right = mid-1;
            }else{
                left = mid+1;
            }
        }
        return right;
    }
};

相关推荐
FakeOccupational3 小时前
【数学 密码学】量子通信:光的偏振&极化的量子不确定性特性 + 量子密钥分发 BB84算法步骤
算法·密码学
ZhengEnCi5 小时前
S10-蓝桥杯 17822 乐乐的积木塔
算法
贾斯汀玛尔斯5 小时前
每天学一个算法--拓扑排序(Topological Sort)
算法·深度优先
大龄程序员狗哥5 小时前
第25篇:Q-Learning算法解析——强化学习中的经典“价值”学习(原理解析)
人工智能·学习·算法
exp_add35 小时前
质数相关知识
算法
小辉同志6 小时前
215. 数组中的第K个最大元素
数据结构·算法·leetcode··快速选择
小O的算法实验室7 小时前
2025年IEEE TITS,基于矩阵的进化计算+面向无线传感器网络数据收集无人机路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
OidEncoder7 小时前
编码器分辨率与机械精度的关系
人工智能·算法·机器人·自动化
memcpy07 小时前
LeetCode 2615. 等值距离和【相同元素分组+前缀和;考虑距离和的增量】中等
算法·leetcode·职场和发展
炽烈小老头7 小时前
【 每天学习一点算法 2026/04/22】四数相加 II
学习·算法