[LeetCode] 367. Valid Perfect Square 检验完全平方数
Given a positive integer num, write a function which returns True if num is a perfect square else False.
Note: Do not use any built-in library function such as sqrt.
Example 1:
Input: 16
Returns: True
Example 2:
Input: 14
Returns: False
Credits:
Special thanks to @elmirap for adding this problem and creating all test cases.
这道题给了我们一个数,让我们判断其是否为完全平方数,那么显而易见的是,肯定不能使用 brute force,这样太不高效了,那么最小是能以指数的速度来缩小范围,那么我最先想出的方法是这样的,比如一个数字 49,我们先对其除以2,得到 24,发现 24 的平方大于 49,那么再对 24 除以2,得到 12,发现 12 的平方还是大于 49,再对 12 除以2,得到6,发现6的平方小于 49,于是遍历6到 12 中的所有数,看有没有平方等于 49 的,有就返回 true,没有就返回 false,参见代码如下:
解法一:
class Solution {
public:
    bool isPerfectSquare(int num) {
        if (num == ) return true;
        long x = num / , t = x * x;
        while (t > num) {
            x /= ;
            t = x * x;
        }
        for (int i = x; i <=  * x; ++i) {
            if (i * i == num) return true;
        }
        return false;
    }
}; 
下面这种方法也比较高效,从1搜索到 sqrt(num),看有没有平方正好等于 num 的数:
解法二:
class Solution {
public:
    bool isPerfectSquare(int num) {
        for (int i = ; i <= num / i; ++i) {
            if (i * i == num) return true;
        }
        return false;
    }
}; 
我们也可以使用二分查找法来做,要查找的数为 mid*mid,参见代码如下:
解法三:
class Solution {
public:
    bool isPerfectSquare(int num) {
        long left = , right = num;
        while (left <= right) {
            long mid = left + (right - left) / , t = mid * mid;
            if (t == num) return true;
            if (t < num) left = mid + ;
            else right = mid - ;
        }
        return false;
    }
};
下面这种方法就是纯数学解法了,利用到了这样一条性质,完全平方数是一系列奇数之和,例如:
1 = 1
4  = 1 + 3
9  = 1 + 3 + 5
16 = 1 + 3 + 5 + 7
25 = 1 + 3 + 5 + 7 + 9
36 = 1 + 3 + 5 + 7 + 9 + 11
....
1+3+...+(2n-1) = (2n-1 + 1)n/2 = n*n
这里就不做证明了,我也不会证明,知道了这条性质,就可以利用其来解题了,时间复杂度为 O(sqrt(n))。
解法四:
class Solution {
public:
    bool isPerfectSquare(int num) {
        int i = ;
        while (num > ) {
            num -= i;
            i += ;
        }
        return num == ;
    }
};
下面这种方法是第一种方法的类似方法,更加精简了,时间复杂度为 O(lgn):
解法五:
class Solution {
public:
    bool isPerfectSquare(int num) {
        long x = num;
        while (x * x > num) {
            x = (x + num / x) / ;
        }
        return x * x == num;
    }
};
这道题其实还有 O(1) 的解法,这你敢信?简直太丧心病狂了,详情请参见论坛上的这个帖子。
Github 同步地址:
https://github.com/grandyang/leetcode/issues/367
类似题目:
参考资料:
https://leetcode.com/problems/valid-perfect-square/
LeetCode All in One 题目讲解汇总(持续更新中...)
[LeetCode] 367. Valid Perfect Square 检验完全平方数的更多相关文章
- [leetcode]367. Valid Perfect Square验证完全平方数
		Given a positive integer num, write a function which returns True if num is a perfect square else Fa ... 
- [LeetCode]367. Valid Perfect Square判断完全平方数
		方法有很多,我觉得比较容易记住的是两个,一个是二分法,在1-num/2中寻找目标数 另一个是数学方法: public boolean isPerfectSquare(int num) { /* 有很多 ... 
- [LeetCode] Valid Perfect Square 检验完全平方数
		Given a positive integer num, write a function which returns True if num is a perfect square else Fa ... 
- Leetcode 367. Valid Perfect Square
		Given a positive integer num, write a function which returns True if num is a perfect square else Fa ... 
- 367. Valid Perfect Square
		原题: 367. Valid Perfect Square 读题: 求一个整数是否为完全平方数,如1,4,9,16,……就是完全平方数,这题主要是运算效率问题 求解方法1:812ms class So ... 
- 【LeetCode】367. Valid Perfect Square 解题报告(Java & Python)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 方法一:完全平方式性质 方法二:暴力求解 方法三:二 ... 
- 【leetcode】367. Valid Perfect Square
		题目描述: Given a positive integer num, write a function which returns True if num is a perfect square e ... 
- 367. Valid Perfect Square判断是不是完全平方数
		[抄题]: Given a positive integer num, write a function which returns True if num is a perfect square e ... 
- [LeetCode] 367. Valid Perfect Square_Easy tag:Math
		Given a positive integer num, write a function which returns True if num is a perfect square else Fa ... 
随机推荐
- HTML+css基础      css的几种形式       css选择器的两大特性
			3.外联样式 css选择器的两大特性 1.继承性:所有跟文本字体有关的属性都会被子元素继承.且权重是0000. 2.层叠性:就是解决选择器权重大小的一种能力,就是看那个选择器的权重大.谁的权重大听谁的 ... 
- Spring @CrossOrigin 通配符 解决跨域问题
			@CrossOrigin 通配符 解决跨域问题 痛点: 对很多api接口需要 开放H5 Ajax跨域请求支持 由于环境多套域名不同,而CrossOrigin 原生只支持* 或者具体域名的跨域支持 所以 ... 
- 成都,我们来啦 | Dubbo 社区开发者日
			[关注 阿里巴巴云原生 公众号,回复关键词"报名",即可参与抽奖!] 活动时间:10 月 26 日 13:00 - 18:00 活动地点:成都市高新区交子大道中海国际中心 233 ... 
- abstract,virtual,override个人
			1.abstract 可以修饰类和方法,修饰方法时只声明不实现: 2.继承实现abstract类必须通过override实现abstract声明的方法,而virtual方法可选择override(重写 ... 
- DevExpress的TreeList实现节点上添加自定义右键菜单并实现删除节点功能
			场景 Winform控件-DevExpress18下载安装注册以及在VS中使用: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/1 ... 
- SQL和T-SQL之间的区别
			对于SQL,在我的上一篇博客中<何谓SQL Server数据库?与Access数据库 有什么区别>里面,已经着重说明了SQL作为访问和处理数据库的标准的计算机语言,所以这里就不做过多强调. ... 
- MySQL基础(一)(启动/停止、登录/退出、语法规范及最基础操作)
			1.启动/停止MySQL服务 启动:net start mysql 停止:net stop mysql 2.MySQL登录/退出 登录:mysql 参数:如果连接的是本地服务器,一般用命令:my ... 
- 用实力燃爆暑期丨i春秋渗透测试工程师线下就业班开课了!
			i春秋&赛虎暑期渗透测试工程师线下就业班开课了! 本期开班地点:北京,面授脱产:四个月. 如果这次没来得及报名的同学也可以选择9月份广州的班次,具体开班时间请咨询谢老师:18513200565 ... 
- Python odoo中嵌入html简单的分页功能
			在odoo中,通过iframe嵌入 html,页面数据则通过controllers获取,使用jinja2模板传值渲染 html页面分页内容,这里写了判断逻辑 <!-- 分页 -->< ... 
- Linux 性能优化排查工具
			下图1为 Linux 性能优化排查工具的总结 图1 诊断 CPU 工具 查看 CPU 核数 总核数 = 物理CPU个数 X 每颗物理CPU的核数 总逻辑CPU数 = 物理CPU个数 X 每颗物理CPU ... 
