LeetCode做题第三天

荒凉一梦 提交于 2019-12-05 20:44:24

LeetCode做题第三天

** 依旧是以简单的题目先开启大脑**

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

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

示例 1:

输入:16
输出:True
示例 2:

输入:14
输出:False

自己做这道题居然超出时间限制了。难受,不过还好,通过 别人的 代码学到了很多,二分查找等等,不过我觉得最有意思的就是第一种方法。
最后附上我最后提交的代码

    最简单的一句代码:return num**0.5 == int(num**0.5)


    class Solution:
        def isPerfectSquare(self, num: int) -> bool:
            i = num
            while i * i > num:
                i = (i + num / i) // 2
            return i * i == num

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/valid-perfect-square
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!