当前位置: 首页 > article >正文

leetcode69--x的平方根

方法一

直接进行简单的循环遍历,找到符合条件的值返回结果即可

class Solution {
    public int mySqrt(int x) {
        for (int i = 0; i <= x; i++) {
            if ((long)i * i <= x && (long)(i + 1) * (i + 1) > x) {
                return i;
            }
        }
        return -1; // 这个返回值实际上不会被触发,因为对于所有正整数 x,总会找到一个 i
    }
}

二分查找法

class Solution {
    public int mySqrt(int x) {
        int left=0,right=x,res=-1;
        while(left<=right){
            int mid=left+(right-left)/2;
            if((long)mid*mid<=x){
                res=mid;
                left=mid+1;
            }else{
                right=mid-1;
            }
        }
        return res;
    }
}

详细解析

  1. 初始化变量

    • left 初始化为 0,表示搜索区间的左边界。
    • right 初始化为 x,表示搜索区间的右边界。
    • res 初始化为 -1,用于存储最终的结果。
  2. 二分查找循环

    • 使用 while (left <= right) 循环,直到 left 超过 right 为止。
    • 在每次迭代中,计算中间值 mid
      int mid = left + (right - left) / 2;
      
      这种计算方式是为了防止 (left + right) / 2 可能导致的整数溢出问题。
  3. 检查中间值

    • 计算 mid * mid 并与 x 进行比较。为了避免整数溢出,将 mid * mid 转换为 long 类型:
      if ((long)mid * mid <= x) {
          res = mid;
          left = mid + 1;
      } else {
          right = mid - 1;
      }
      
    • 如果 mid * mid 小于或等于 x,说明 mid 是一个可能的解,更新 resmid,并将 left 移动到 mid + 1,继续在右半部分查找更大的可能解。
    • 如果 mid * mid 大于 x,说明 mid 太大了,需要在左半部分查找更小的解,因此将 right 移动到 mid - 1
  4. 返回结果

    • left 超过 right 时,循环结束,此时 res 存储的就是 x 的平方根(向下取整)。

http://www.kler.cn/news/329355.html

相关文章:

  • Python编程和开发过程中让人编程效率和舒适度很高的工具Anaconda
  • 深入理解Spring Boot的自动装配原理
  • 墙绘艺术在线交易:SpringBoot技术解析
  • 从零开始Ubuntu24.04上Docker构建自动化部署(二)Docker-安装docker-compose
  • Linux下的git开篇第一文:git的意义
  • DDOS攻击会对网站服务器造成哪些影响?
  • 【Qt】Qt中的窗口坐标 信号与槽
  • Jenkins: fontconfig head is null, check your fonts or fonts configuration;
  • Hive数仓操作(十一)
  • mac访达查找文件目录
  • harproxy
  • zabbix7.0通过端口监控服务案例详解
  • 如何配置路由器支持UDP
  • post请求失败failed The system cannot find the path specified
  • Redis篇(缓存机制 - 基本介绍)(持续更新迭代)
  • Mac安装Manim并运行
  • Python中流行的开源OCR项目
  • 10/02赛后总结
  • 【Android 源码分析】Activity生命周期之onStop-1
  • 【重学 MySQL】四十七、表的操作技巧——修改、重命名、删除与清空
  • 前端学习第一天笔记 HTML5 CSS初学以及VSCODE中的常用快捷键
  • 基于AutoDL复现Nice-slam
  • C++入门基础 (超详解)
  • Thinkphp/Laravel基于vue的实验室上机管理系统
  • 基于Python的屏幕录制转GIF工具
  • VisionPro - 基础 - 模板匹配技术-应用3 - Search\PMAline\PatMax\Alignment Guidelines
  • 使用VBA快速生成Excel工作表非连续列图片快照
  • 二、创建drf纯净项目
  • LeetCode 152. 乘积最大子数组
  • TIM(Timer)定时器的原理