leetcode刷题367.有效的完全平方数

本文探讨了在不使用sqrt函数的情况下,如何判断一个数是否为完全平方数。提出了两种方法,一种是通过计算因子数量判断,但由于效率问题被舍弃;另一种是利用完全平方数之间的间隔特性进行判断,最终实现了高效的解决方案。
摘要由CSDN通过智能技术生成

题目描述

给定一个正整数 num,编写一个函数,如果 num 是一个完全平方数,则返回 True,否则返回 False。
说明:不要使用任何内置的库函数,如 sqrt。

示例

输入:16
输出:True

输入:14
输出:False

首先,想到的是sqrt,但是本题禁止使用sqrt。
其次,想到完全平方数另一个性质,即完全平方数的充分必要条件是包含奇数个因子(包括1和本身)
所以可以使用一个for循环来计算因子数量,判断是否为奇数,但不幸的是,超时,代码如下:

class Solution {
public:
    bool isPerfectSquare(int num) {
        int count=0;
        for(int i=1;i<=num;i++)
        {
            if(num%i==0)
            count++;
        }
        if(count%2==1)
        return true;
        return false;
    }
};

痛定思痛,这么好的方法居然超时,只好另辟蹊径,于是乎想到了任何两个完全平方数之间都不可能拥有完全平方数,哎?这机会不就来了嘛!!!
于是一番操作下,代码如下:

class Solution {
public:
    bool isPerfectSquare(int num) {
        if(num==0)
        return true;
        if(num==1)
        return true;
        long long a,b,i=1;
        while(i++)
        {
            a=i*i;
            b=(i+1)*(i+1);
            if(num>a&&num<b)
            return false;
            if(a==num||b==num)
            return true;
        }
        return false;
    }
};

作为第一道在leetcode刷的两个100%,我表示很开心
在这里插入图片描述

需要注意的是:
1.当没有加最后一行return false时,报出如下错误:fatal error: control may reach end of non-void function [-Wreturn-type]
这是因为当if不执行的时候,可能会没有返回值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值