Leetcode 每日一题69.x的平方根

🌈🌈🌈今天给大家分享的是:leetcode简单题{x的平方根}

目录

问题描述

输入输出格式

示例

算法分析

算法步骤

过题图片

代码实现

注意事项

题目链接

结论


问题描述

给定一个非负整数 x,我们需要计算并返回 x 的算术平方根,并且只保留整数部分,小数部分将被舍去。不允许使用任何内置指数函数和算符,如 pow(x, 0.5)x ** 0.5

输入输出格式

  • 输入 :一个非负整数 x
  • 输出x 的算术平方根的整数部分。

示例

  1. 输入:x = 4,输出:2
  2. 输入:x = 8,输出:2(因为 8 的算术平方根是 2.82842...,我们只取整数部分)。

算法分析

这个问题可以通过二分查找算法来解决。二分查找是一种在有序数组中查找特定元素的算法,其时间复杂度为 O(log n)。在这个问题中,我们可以将二分查找应用于寻找整数平方根。

算法步骤

  1. 初始化两个指针 lr,分别指向搜索范围的左边界(1)和右边界(x)。
  2. l 小于等于 r 的条件下循环:
    • 计算中间值 mid,为 lr 的平均值,即 mid = l + (r - l) / 2
    • 计算 mid 的平方与 x 的关系:
      • 如果 x / mid >= mid,则说明 mid 可能是平方根,或者平方根在 mid 的右边,因此将 l 设置为 mid + 1
      • 否则,平方根在 mid 的左边,将 r 设置为 mid - 1
  3. 循环结束后,ans 将保存 x 的算术平方根的整数部分。

过题图片

代码实现

复制代码
class Solution {
    public int mySqrt(int x) {
        int l = 1;
        int r = x;
        int ans = 0;
        while (l <= r) {
            int mid = l + (r - l) / 2;
            long square = (long) mid * mid; // 用 long 防止溢出
            if (square <= x) {
                l = mid + 1;
                ans = mid;
            } else {
                r = mid - 1;
            }
        }
        return ans;
    }
}

注意事项

  • 在计算 mid 的平方时,我们将其转换为 long 类型以防止整数溢出。
  • 由于题目要求返回整数部分,我们不需要考虑小数点后的值。

题目链接

69. x 的平方根 - 力扣(LeetCode)

结论

通过二分查找算法,我们可以高效地计算出一个非负整数的算术平方根的整数部分。

🌈🌈🌈好啦,今天的分享就到这里!

🛩️🛩️🛩️希望各位看官读完文章后,能够有所提升。

🎉🎉🎉创作不易,还希望各位大佬支持一下!

✈️✈️✈️点赞,你的认可是我创作的动力!

⭐⭐⭐收藏,你的青睐是我努力的方向!

✏️✏️✏️评论:你的意见是我进步的财富!

相关推荐
小O的算法实验室10 小时前
2024年IEEE TITS SCI2区TOP,考虑无人机能耗与时间窗的卡车–无人机协同路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
派森先生10 小时前
排序算法-选择排序
算法·排序算法
C雨后彩虹10 小时前
书籍叠放问题
java·数据结构·算法·华为·面试
ghie909010 小时前
GPS抗干扰算法MATLAB实现
开发语言·算法·matlab
格林威10 小时前
基于轮廓特征的工件分类识别:实现无模板快速分拣的 8 个核心算法,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·算法·目标跟踪·分类·数据挖掘
Jasmine_llq10 小时前
《UVA11181 条件概率 Probability|Given》
数据结构·算法·深度优先搜索(dfs)·剪枝(可行性剪枝)·组合枚举(递归暴力枚举)·条件概率统计与归一化
老鼠只爱大米10 小时前
LeetCode算法题详解 560:和为K的子数组
算法·leetcode·前缀和·哈希表·子数组求和·subarraysum
MM_MS10 小时前
Halcon小案例--->路由器散热口个数(两种方法)
人工智能·算法·目标检测·计算机视觉·视觉检测·智能路由器·视觉
小杨同学4910 小时前
C 语言实战:超市水果结算系统(深度解析与优化)
后端·算法·设计
码农水水11 小时前
中国电网Java面试被问:流批一体架构的实现和状态管理
java·c语言·开发语言·面试·职场和发展·架构·kafka