目录

69.x的平方根-力扣(LeetCode)

题目:

解题思路:

解决本题主要运用的方法是二分法,二分法是一种在有序数组中查找某一特定元素的搜索算法。鉴于本题满足整个序列是有序的,并且可以通过比较来改变区间,满足二分法的应用条件,所以采用二分法。

根据x是有符号整型数据,那么右区间可以确定为46341(根据x的最大值开方得到),在循环中不断进行比较和更新区间的操作,循环后,左边界的值即为目标元素,在整个过程中注意区间边界的赋值。

一个注意点是:if(mid * mid == x)中,mid * mid产生的中间结果可能会超出int类型的范围,在LeetCode中提交会报错,所以要改为范围更大的long类型或者long long类型(在自己的编辑器中,可能不会报这个错误)。

代码:

cpp 复制代码
int mySqrt(int x)
{
    int l = 0,r = 46341;//定义左右区间
    while(l < r)
    {
        long mid = l+(r-l)/2+1;//获取区间中点
        if(mid * mid == x)//找到目标元素
        {
            return mid;
        }
        else if(mid * mid > x)//目标元素在左区间
        {
            r = mid - 1;//更新区间
        }
        else//目标元素在右区间
        {
            l = mid;//更新区间
        }
    }
    //循环结束,此时l * l = x
    return l;
}
本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
记得早睡~7 小时前
leetcode122-买卖股票的最佳时机II
javascript·数据结构·算法·leetcode
weisian15111 小时前
力扣经典算法篇-9-跳跃游戏(贪心算法,反向递推)
算法·leetcode·游戏
努力也学不会java12 小时前
【动态规划】深入动态规划 非连续子序列问题
java·数据结构·算法·leetcode·动态规划
Chandler2412 小时前
LeetCode 热题 100 堆
算法·leetcode
@蓝莓果粒茶15 小时前
LeetCode第132题_分割回文串II
开发语言·算法·leetcode·职场和发展·c#·.net·linq
阳洞洞16 小时前
二叉树的层序遍历
数据结构·算法·leetcode·二叉树遍历·广度优先搜索
今天也要早睡早起16 小时前
代码随想录算法训练营Day32| 完全背包问题(二维数组 & 滚动数组)、LeetCode 518 零钱兑换 II、377 组合总数 IV、爬楼梯(进阶)
数据结构·c++·算法·leetcode·动态规划·完全背包
梭七y19 小时前
【力扣hot100题】(063)搜索二维矩阵
算法·leetcode·职场和发展
@蓝莓果粒茶20 小时前
LeetCode第131题_分割回文串
开发语言·前端·算法·leetcode·职场和发展·c#·.net
雾里看山20 小时前
算法思想之滑动窗口(一)
算法·leetcode·推荐算法