实现 int sqrt(int x) 函数 ------------------------------------ 实现 int sqrt(int x) 函数。 计算并返回 x 的平方根,其中 x 是非负整数。 由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去。 示例 1:: 输入: 4 输出: 2 示例 2:: 输入: 8 输出: 2 说明: 8 的平方根是 2.82842..., 由于返回类型是整数,小数部分将被舍去。 """ 如果不调用系统的sqrt函数,那有一个方法来实现,就是从1开始计算,直到计算平方大于x时,上一个数字就是 平方根。 代码如下:: import unittest class Solution: def mySqrt(self, x): """ :type x: int :rtype: int """ tmp = 1 for i in range(1, x//2+1): if(i*i<=x): tmp = i else: break; return tmp class TestmySqrtFunc(unittest.TestCase): """Test case""" def test_mySqrt(self): """Test method mySqrt(self, x)""" s = Solution() self.assertEqual(2, s.mySqrt(4)) self.assertEqual(2, s.mySqrt(8)) self.assertEqual(3, s.mySqrt(9)) if __name__ == '__main__': unittest.main()