Skip to content

Latest commit

 

History

History
126 lines (100 loc) · 2.44 KB

069._sqrt(x).md

File metadata and controls

126 lines (100 loc) · 2.44 KB

69. Sqrt(x)

难度: Easy

刷题内容

原题连接

内容描述

Implement int sqrt(int x).

Compute and return the square root of x, where x is guaranteed to be a non-negative integer.

Since the return type is an integer, the decimal digits are truncated and only the integer part of the result is returned.

Example 1:

Input: 4
Output: 2
Example 2:

Input: 8
Output: 2
Explanation: The square root of 8 is 2.82842..., and since 
             the decimal part is truncated, 2 is returned.

解题方案

思路 1

一看,觉得很容易,一写,超时:

class Solution(object):
    def mySqrt(self, x):
        """
        :type x: int
        :rtype: int
        """
        i = 0
        while i * i <= x :
        	if i * i == x:
        		return i 
        	elif i * i < x and (i+1) * (i+1) > x:
        		return i
        	i += 1

思路 2

看一眼tag, binary search,难道从x/2之类的开始搜起来?

莫名其妙过了的代码:

class Solution(object):
    def mySqrt(self, x):
        """
        :type x: int
        :rtype: int
        """
        if x == 0:
            return 0
        if x == 1:
            return 1
        l, r = 0, x - 1
        while l <= r:
            mid = l + ((r-l) >> 1)
            if mid * mid <= x and (mid+1) * (mid+1) > x:
                return mid
            elif mid * mid > x:
                r = mid - 1    # 这里也可以 r = mid
            else:
                l = mid + 1

思路 3

跟思路 2 一样,就是return时机不一样

class Solution(object):
    def mySqrt(self, x):
        """
        :type x: int
        :rtype: int
        """
        if x == 1:
            return 1
        if x == 0:
            return 0
        l, r = 0, x-1
        while l <= r:
            mid = l + ((r - l) >> 2)
            if (mid * mid - x == 0):
                return mid
            elif (mid * mid - x > 0):
                r = mid - 1
            else:
                l = mid + 1
        return r

思路 4

话说还想到求sqrt有个🐂的牛顿法?

牛顿法 wiki

class Solution(object):
    def mySqrt(self, x):
        """
        :type x: int
        :rtype: int
        """
        res = 1.0
        while abs(res * res - x) > 0.1:
            res = (res + x / res) / 2
        return int(res)