《LeetCode之每日一题》:197.有效的完全平方数

有效的完全平方数


题目链接: 有效的完全平方数

有关题目

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

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

输入:num = 16
输出:true

示例 2:

输入:num = 14
输出:false
提示:

1 <= num <= 2^31 - 1

题解

法一:库函数
代码一:

class Solution {
public:
    bool isPerfectSquare(int num) {
        int x = (int)sqrt(num);
        return  x * x == num;
        //还可以利用e ^ (0.5 * ln (x)) == 根号x求解
    }
};

法二:暴力法
参考官方题解

class Solution {
public:
    bool isPerfectSquare(int num) {
        long x = 1, squre = 1;

        while(squre <= num)
        {
            if (squre == num)
                return true;
            
            x++;
            squre = x * x;
        }

        return false;
    }
};

在这里插入图片描述
法三:二分查找

class Solution {
public:
    bool isPerfectSquare(int num) {
        int l = 0, r = num;
        while(l <= r)
        {
            long mid = (r - l) / 2 + l;//防止溢出
            if (mid * mid == num)
                return true;
            else if (mid * mid < num)
                l = mid + 1;
            else 
                r = mid - 1;
        }
        return false;
    }
};

在这里插入图片描述
法四:牛顿迭代法

class Solution {
public:
    bool isPerfectSquare(int num) {
        double x0 = num;
        while(true)
        {
            double x1 = 0.5 * (x0 + num / x0);
            if (x0 - x1 <= 1e-7)
                break;
            x0 = x1;
        }

        int x = (int)x0;
        return x * x == num;
    }
};

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值