• 【手绘漫画】图解LeetCode之x 的平方根(LeetCode 69题)


    在这里插入图片描述

    图解LeetCode刷题计划

    1、写在前面

    手绘漫画系列正式上线!!!“图解LeetCode刷题计划” 来了!!!

    今天是第七期,争取每天一期,最多两天一期,欢迎大家监督我。。。
    在这里插入图片描述
    最近依旧是二分查找算法呢~

    使用新版的模板加上图解,相信你能更加理解二分法的使用!!!
    在这里插入图片描述

    2、题目

    首先看一下题目,
    在这里插入图片描述
    分界条件就是我们的 mid * midx 的关系!!!
    在这里插入图片描述
    在这里插入图片描述

    3、正文

    首先分析一下情况,

    确定一下 leftright,然后编写二分查找模板。
    在这里插入图片描述
    可以看到,mid * mid <= x 时,所以 targetmid 的右侧,因为有等号,所以 left = midmid * mid <= x 这么写不好,容易溢出,所以可以写成 mid<=x/mid

    因为是模板二,所以不要忘记给 mid 加1!!!
    在这里插入图片描述

    4、代码

    int mySqrt(int x){
        int left=0;
        int right=x;
        while(left<right){
            int mid=(long)left+right+1>>1;
            if(mid<=x/mid){
                left=mid;
            }
            else{
                right=mid-1;
            }
        }
        return left;
    }
    

    在这里插入图片描述
    在这里插入图片描述

    如果有幸帮到你,请帮我点个【赞】,给个【关注】!如果能顺带【评论】给个鼓励,我将不胜感激。

    如果想要更多的资源,欢迎关注 @我是管小亮,文字强迫症MAX~

  • 相关阅读:
    第 9 章 类
    导入模块
    第 8 章 函数
    第七章 用户输入和while语句
    第六章 字典
    测试经理/组长职责
    测试的发展之路
    【转】测试流程
    一个网页通用的测试用例(借鉴他人的保存,加注释)
    QTP自动化测试框架简述
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13302577.html
Copyright © 2020-2023  润新知