力扣每日一题2021-11-04有效的完全平方数


367.有效的完全平方数

题目描述

有效的完全平方数


思路:库函数、暴力遍历、二分查找

库函数

最朴素的解法是用库函数。

Python实现

Python实现

class Solution:
    def isPerfectSquare(self, num: int) -> bool:
        # 库函数
        return float.is_integer(pow(num, 0.5))
Java实现

Java实现

class Solution {
    public boolean isPerfectSquare(int num) {
        // 库函数
        int x = (int) Math.sqrt(num);
        return x * x == num;
    }
}

暴力遍历

假定num为有效的完全平方数,则一定存在正整数x使得xx=num。于是可以从1开始遍历正整数,寻找是否存在满足xx=num的正整数x。在遍历过程中,如果存在正整数x使得xx>num,则不可能再出现正整数x使得xx=num成立,不再继续遍历。

Python实现

Python实现

class Solution:
    def isPerfectSquare(self, num: int) -> bool:
        # 暴力遍历
        x, square = 1, 1
        while square <= num:
            if square == num:
                return True
            x += 1
            square = x * x
        return False
Java实现
class Solution {
    public boolean isPerfectSquare(int num) {
        // 暴力遍历
        long x = 1, square = 1;
        while (square <= num) {
            if (square == num) {
                return true;
            }
            ++x;
            square = x * x;
        }
        return false;
    }
}

二分查找

可以使用二分查找对暴力遍历进行优化,由于num是正整数,所以如果正整数x满足x*x=num,则x一定满足1 <= x <= num。所以可以使用1和num作为两个边界。

Python实现

Python实现

class Solution:
    def isPerfectSquare(self, num: int) -> bool:
        # 二分查找
        left, right = 0, num
        while left <= right:
            mid = (left + right) // 2
            square = mid * mid
            if square < num:
                left = mid + 1
            elif square > num:
                right = mid - 1
            else:
                return True
        return False
Java实现

Java实现

class Solution {
    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;
    }
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值