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)

结论

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

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

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

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

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

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

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

相关推荐
IT猿手1 小时前
无人机(Unmanned Aerial Vehicle, UAV)路径规划介绍
算法·matlab·无人机·智能优化算法·多目标算法
玉面小君7 小时前
C# 数据拟合教程:使用 Math.NET Numerics 的简单实现
算法·c#·c·数据拟合
ydm_ymz8 小时前
句子读单词
c语言·数据结构·算法·排序算法
KeyPan9 小时前
【机器学习:三十三(一)、支持向量机】
人工智能·神经网络·算法·机器学习·支持向量机·数据挖掘·迁移学习
笔写落去9 小时前
统计学习方法(第二版) 第七章 支持向量机 (第三节)
人工智能·算法·机器学习·支持向量机
yjhqukq9 小时前
递归40题!再见递归
c语言·数据结构·c++·算法·链表·双向链表
飞yu流星9 小时前
c++ string
开发语言·c++·算法
爱吃涮毛肚的肥肥(暂时吃不了版)11 小时前
Leetcode——链表:143.重排链表
数据结构·c++·后端·算法·leetcode·链表·职场和发展
dundunmm11 小时前
论文阅读:Structure-Driven Representation Learning for Deep Clustering
论文阅读·人工智能·算法·数据挖掘·聚类·深度聚类
Joyner201813 小时前
python-leetcode-同构字符串
算法·leetcode·职场和发展