• 【手绘漫画】图解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~

  • 相关阅读:
    vi命令大全
    理解proc文件系统
    读目录
    取得系统资源信息
    qtempinc
    我实现的一个正则表达式代码
    oracle内置函数大全
    STL算法
    unix基础教程
    两日期间的天数
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13302577.html
Copyright © 2020-2023  润新知