LeetCode:Sqrt(x) - 整数开方

原文链接: https://my.oschina.net/Tsybius2014/blog/491571

1、题目名称

Sqrt(x)(整数开方)

2、题目地址

https://leetcode.com/problems/sqrtx

3、题目内容

英文:Implement int sqrt(int x). Compute and return the square root of x.

中文:实现函数,实现整数x的开平方运算

4、解题方法1

做这个题目,最简单的方法莫过于使用语言自带数学函数库中的sqrt函数式,例如下面的Java代码:

/**
 * 功能说明:LeetCode 69 - Sqrt(x)
 * 开发人员:Tsybius2014
 * 开发时间:2015年8月12日
 */
public class Solution {

    /**
     * 开平方根 
     * @param x 被开方数
     * @return 算术平方根
     */
    public int mySqrt(int x) {
        return (int)Math.sqrt((double)x);
    }
}

5、解题方法2

上面的方法较为简短,但也存在一个缺点:因为是整数开方,向下取整,因此不需要浮点数那么高的精度,就可以计算出正确的整型结果返回了。因此可以尝试使用牛顿法进行开方,并且while语句内并不像一般计算浮点数开方那样保证误差精确到1E-9以下,而是设置为任意比1小的数字就可以了。

牛顿法开平方公式如下:

212343_hufv_1425762.png

具体内容可参看维基百科页面:【平方根】条目下的【牛顿法】章节

https://zh.wikipedia.org/wiki/%E5%B9%B3%E6%96%B9%E6%A0%B9#.E7.89.9B.E9.A0.93.E6.B3.95

对于这个题目而言,下面这段Java代码执行时间更短:

/**
 * 功能说明:LeetCode 69 - Sqrt(x)
 * 开发人员:Tsybius2014
 * 开发时间:2015年8月12日
 */
public class Solution {

    /**
     * 开平方根 
     * @param x 被开方数
     * @return 算术平方根
     */
    public int mySqrt(int x) {
        if (x <= 0) {
            return 0;
        }
        double result = 1.0;
        while (Math.abs(result * result - x) > 0.9) {
            result = (result + x / result) / 2.0;
        }
        return (int)result;
    }
}

END

转载于:https://my.oschina.net/Tsybius2014/blog/491571

你可能感兴趣的:(LeetCode:Sqrt(x) - 整数开方)