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)

结论

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

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

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

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

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

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

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

相关推荐
逻辑驱动的ken几秒前
Java高频面试考点场景题22
java·开发语言·jvm·面试·职场和发展·求职招聘·春招
m0_629494732 分钟前
LeetCode 热题 100-----18.矩阵置零
数据结构·leetcode·矩阵
生成论实验室19 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第十篇:识势应势——从认知到行动的完整闭环
人工智能·算法·架构·创业创新·安全架构
risc12345621 分钟前
SegmentTermsEnum#postings 和 IntersectTermsEnum#postings
算法·lucene
阿Y加油吧24 分钟前
二刷 LeetCode:两道经典贪心题复盘
算法·leetcode·职场和发展
顺顺 尼24 分钟前
程序地址空间和进程的一些操作
算法
Java成神之路-27 分钟前
【LeetCode 刷题笔记】35. 搜索插入位置 | 二分查找经典入门题
算法·leetcode
计算机魔术师30 分钟前
【职场观察 | 技术人处境】五一假期结束,职场两边同时加速——“简历热“和“优化潮“背后的结构性逻辑
人工智能·面试·职场和发展·cot 推理·技术人求职·ai替代逻辑
MediaTea11 小时前
AI 术语通俗词典:C4.5 算法
人工智能·算法
Navigator_Z11 小时前
LeetCode //C - 1033. Moving Stones Until Consecutive
c语言·算法·leetcode