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;
}
相关推荐
Swift社区44 分钟前
LeetCode 429 - N 叉树的层序遍历
算法·leetcode·职场和发展
无敌最俊朗@11 小时前
力扣hot100-206反转链表
算法·leetcode·链表
Kuo-Teng11 小时前
LeetCode 279: Perfect Squares
java·数据结构·算法·leetcode·职场和发展
CoderYanger12 小时前
B.双指针——3194. 最小元素和最大元素的最小平均值
java·开发语言·数据结构·算法·leetcode·职场和发展·1024程序员节
前进的李工14 小时前
LeetCode hot100:094 二叉树的中序遍历:从递归到迭代的完整指南
python·算法·leetcode·链表·二叉树
吃着火锅x唱着歌16 小时前
LeetCode 面试题 16.24.数对和
算法·leetcode·职场和发展
Dream it possible!16 小时前
LeetCode 面试经典 150_二叉树层次遍历_二叉树的层平均值(82_637_C++_简单)
c++·leetcode·面试·二叉树
Wenhao.16 小时前
LeetCode Hot100 每日温度
数据结构·算法·leetcode·golang
吃着火锅x唱着歌16 小时前
LeetCode 1679.K和数对的最大数目
算法·leetcode·职场和发展
im_AMBER16 小时前
Leetcode 57
笔记·学习·算法·leetcode