力扣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

代码:

cpp 复制代码
class Solution {
public:
    int mySqrt(int x) {
        int left = 0, right = x, res = -1;
        
        while(left <= right){
            long long mid = (left + right) / 2;

            if(mid * mid <= x){
                res = mid;
                left = mid + 1;
            }
            else{
                right = mid - 1;
            }
        }

        return res;
    }
};

解题思路:

(1)使用二分查找的思路。

(2)若 mid * mid 小于 x,则赋值给 res。

(3)循环结束后,res 即为最终结果。

相关推荐
NAGNIP12 分钟前
机器学习特征工程中的特征选择
算法·面试
l1t18 分钟前
DeepSeek辅助编写的利用位掩码填充唯一候选数方法求解数独SQL
数据库·sql·算法·postgresql
Z1Jxxx22 分钟前
反序数反序数
数据结构·c++·算法
副露のmagic23 分钟前
更弱智的算法学习 day25
python·学习·算法
求梦82023 分钟前
【力扣hot100题】移动零(1)
算法·leetcode·职场和发展
NAGNIP27 分钟前
机器学习中的数据预处理方法大全!
算法·面试
涛涛北京35 分钟前
Soft-Actor-Critic算法-连续环境
算法
vyuvyucd37 分钟前
C++排序算法全解析
java·数据结构·算法
胡萝卜不甜39 分钟前
算法宗门---迪杰斯特拉Dijkstra(最短路径算法)
算法
练习时长一年1 小时前
LeetCode热题100(爬楼梯)
算法·leetcode·职场和发展