力扣第33刷-有效的完全平方数

简介: 力扣第33刷-有效的完全平方数

Example 33

有效的完全平方数

题目概述:给定一个 正整数 num ,编写一个函数,如果 num 是一个完全平方数,则返回 true ,否则返回 false 。

进阶:不要使用任何内置的库函数,如sqrt 。

示例 1:

输入:num = 16

输出:true

示例 2:

输入:num = 14

输出:false

解题思路:使用二分查找。因为num 是正整数,所以若正整数x满足x*x=num,则x一定满足 1≤x≤num。于是可以将1和num作为二分查找搜索区间的初始边界。

因为在移动左侧边界left和右侧边界right时,新的搜索区间都不会包含被检查的下标mid,所以搜索区间的边界始终是没有检查过的。因此,当left=right时,仍需要检查mid=(left+right)/2。

解题步骤:

1. 定义变量left、right分别代表左、右指针指向的索引,其初值分别为0,num。

2. 定义while循环,当left小于等于right时,进入循环,继续考察,否则说明二分查找法首尾已经错开,且仍为找到目标值,即代表没有目标值,返回false。

3. 在while循环内部,定义变量mid代表当前起始点与终点的中间点。定义变量square代表中间点的平方(为避免平方时出现数据溢出,square应当定义为long型),以此与num作比较来判断目标值在mid的左/右侧。

4. 若square小于num,则说明目标值在mid的右侧,则将起始点更新为mid + 1,若square大于num,则说明目标值在mid的左侧,则将终点更新为mid - 1,否则说明square等于num,即找到目标点,返回true。

 

示例代码如下:

public class EffectiveCompleteSquare {
    /**
     * 给定一个 正整数 num ,编写一个函数,如果 num 是一个完全平方数,则返回 true ,否则返回 false 。
     * 进阶:不要使用任何内置的库函数,如sqrt 。
     * 示例 1:
     * 输入:num = 16
     * 输出:true
     * 示例 2:
     * 输入:num = 14
     * 输出:false
     * 来源:力扣(LeetCode)
     * 链接:https://leetcode.cn/problems/valid-perfect-square
     */
    public static void main(String[] args) {
        EffectiveCompleteSquare ecs = new EffectiveCompleteSquare();
        System.out.println(ecs.isPerfectSquare(2147483647)); // true
    }
    /**
     * 官方
     *
     * @param num
     * @return
     */
    public boolean isPerfectSquare(int num) {
        int left = 0, right = num;
        while (left <= right) {
            int mid = (right - left) / 2 + left;
            long square = (long) mid * mid;
            if (square < num) {
                left = mid + 1;
            } else if (square > num) {
                right = mid - 1;
            } else {
                return true;
            }
        }
        return false;
    }
    /**
     * 个人
     * @param num
     * @return
     */
    /*public boolean isPerfectSquare(int num) {
        int strat = 0;
        int end = num;
        long mid;
        while (strat <= end) {
            mid = (end + strat) / 2;
            if (mid * mid == num) return true;
            else if (mid * mid < num) strat = (int)mid + 1;
            else end = (int)mid - 1;
        }
        return false;
    }*/
}
相关文章
|
7月前
|
Go
golang力扣leetcode 279.完全平方数
golang力扣leetcode 279.完全平方数
50 0
|
7月前
|
Java
leetcode-279:完全平方数
leetcode-279:完全平方数
65 0
【Leetcode -367.有效的完全平方数 -374.猜数字大小】
【Leetcode -367.有效的完全平方数 -374.猜数字大小】
48 0
|
4月前
|
Python
【Leetcode刷题Python】279. 完全平方数
LeetCode 279题 "完全平方数" 的Python解决方案,使用动态规划来找到和为给定整数n的完全平方数的最少数量。
38 0
|
4月前
|
Python
【Leetcode刷题Python】367. 有效的完全平方数
本文提供了两种判断一个正整数是否为完全平方数的Python实现方法:一种是利用数学公式逐个减去奇数的方法,另一种是使用二分查找优化的暴力求解方法。
70 0
【超直白】leetcode 279 完全平方数
【超直白】leetcode 279 完全平方数
|
6月前
|
算法
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值
|
7月前
[leetcode ~dp ]279. 完全平方数
[leetcode ~dp ]279. 完全平方数
|
7月前
代码随想录 Day38 完全背包问题 LeetCode T70 爬楼梯 T322 零钱兑换 T279 完全平方数
代码随想录 Day38 完全背包问题 LeetCode T70 爬楼梯 T322 零钱兑换 T279 完全平方数
40 0
|
7月前
leetcode279完全平方数刷题打卡
leetcode279完全平方数刷题打卡
38 0