天天看点

leetcode之Valid Perfect Square

这题是用来求一个数是不是另一个数的平方。用二分法可以轻松解决。每次看中间的数的平方与之比较,大了,则中间数为新的list的上限,反之亦然。

class Solution(object):
    def __init__(self):
        self.list1 = []
    def isPerfectSquare(self, num):
        """
        :type num: int
        :rtype: bool
        """
        if num ==  or num == :
            return True
        if num < :
            return False
        if self.list1 == []:
            self.list1 = [, int(num/)]
        middle = int((self.list1[] + self.list1[-])/)
        if middle **  == num:
            return True
        elif middle **  < num:
            self.list1 = [middle, self.list1[-]]
        else:
            self.list1 = [self.list1[], middle]
        if self.list1[] >= self.list1[-] - :
            return False
        else:
            return self.isPerfectSquare(num)