算法第三天力扣第69题:X的平方根

69. x 的平方根(可点击下面链接或复制网址进行做题)https://leetcode.cn/problems/sqrtx/https://leetcode.cn/problems/sqrtx/

给你一个非负整数 x ,计算并返回 x算术平方根

由于返回类型是整数,结果只保留 整数部分 ,小数部分将被 舍去 。

注意: 不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5

示例 1:

复制代码
  输入:x = 4
  输出:2

示例 2:

复制代码
  输入:x = 8
  输出:2
  解释:8 的算术平方根是 2.82842..., 由于返回类型是整数,小数部分将被舍去。
  提示:0 <= x <= 2**31 - 1

利用二分查找(c++)的方法解题如下所示(省略力扣的起始内容)

cpp 复制代码
        int ans=-1, left=0, right=x;
        while(left<=right){
            long long mid=left+(right-left)/2; //中间值
            if(mid<=pow(x, 0.5)){
                ans=mid;
                left=mid+1;
            }else{
                right=mid-1;
            }
        }
        return ans;

解题思路:根据题意定义左右端点的值,找中间值mid为left+(right-left)/2,而且类型必须是long long型,原因是0<=x<=2**31-1。如果mid<=pow(x, 0.5),更新左边界为left=mid+1;反之,更新右边界为right=mid-1。最后,输出结果值。

感谢各位读者的阅读与支持,您的支持是我前进的动力!我希望我的博文能够带给您有益的信息和启发,让您的生活更加丰富多彩。如果您有任何问题或意见,请随时联系我或在评论区评论。再次感谢您的支持!希望以上示例对大家有帮助,如有疑问,欢迎您在评论区评论,谢谢!!!

二分查找的知识点如下链接所示,感兴趣的读者可点击链接或复制网址打开进行学习:

https://mp.csdn.net/mp_blog/creation/editor/139318710

相关推荐
招摇的一半月亮39 分钟前
P2242 公路维修问题
数据结构·c++·算法
f***01932 小时前
CC++链接数据库(MySQL)超级详细指南
c语言·数据库·c++
合方圆~小文2 小时前
球型摄像机作为现代监控系统的核心设备
java·数据库·c++·人工智能
椰萝Yerosius3 小时前
[题解]2024CCPC郑州站——Z-order Curve
c++·算法
滨HI06 小时前
C++ opencv简化轮廓
开发语言·c++·opencv
学习路上_write6 小时前
FREERTOS_互斥量_创建和使用
c语言·开发语言·c++·stm32·单片机·嵌入式硬件
闻缺陷则喜何志丹7 小时前
【SOSDP模板 容斥原理 逆向思考】3757. 有效子序列的数量|分数未知
c++·算法·力扣·容斥原理·sosdp·逆向思考
BestOrNothing_20158 小时前
一篇搞懂 C++ 重载:函数重载 + 运算符重载,从入门到会用(含 ++、<<、== 实战)
c++·函数重载·运算符重载·operator·前置后置++·重载与重写
2501_941144428 小时前
Python + C++ 异构微服务设计与优化
c++·python·微服务
程序猿编码8 小时前
PRINCE算法的密码生成器:原理与设计思路(C/C++代码实现)
c语言·网络·c++·算法·安全·prince