69. Sqrt(x)

2019-03-06  本文已影响0人  FlyCharles

1. 我的AC

方法一

class Solution(object):
    def mySqrt(self, x):
        """
        :type x: int
        :rtype: int
        """
        for n in range(x/2 + 1):
            if x >= n ** 2 and x < (n + 1) ** 2:
                return n

方法二

class Solution(object):
    def mySqrt(self, x):
        """
        :type x: int
        :rtype: int
        """
        return int(x ** 0.5)

方法三

二分查找.png
class Solution(object):
    def mySqrt(self, x):
        """
        :type x: int
        :rtype: int
        """
        l, r = 0, x
        while l <= r:
            mid = (l + r) // 2
            if x >= mid ** 2 and x < (mid + 1) ** 2:
                return mid
            elif x < mid ** 2:
                r = mid
            else:
                l = mid + 1

2. 小结

  1. 整数开根号
int(x ** 0.5)
  1. 两个变量同时赋值
错误
l = 0, r = x
正确
l, r = 0, x
  1. 两种除法运算符:///

关于/

>>> 3/2
1
>>> 3/2.0
1.5
>>> 3.0/2
1.5
>>> 10/3.0
3.3333333333333335

关于//

>>> 3//2
1
>>> 3//2.0
1.0
>>> 3.0//2
1.0
>>> 3.0//2.0
1.0

参考:https://www.jianshu.com/p/9034aafb50aa

上一篇 下一篇

猜你喜欢

热点阅读