LeetCode:Sqrt(x) - 整数开方

一、题目名称java

Sqrt(x)(整数开方)函数

二、题目地址code

https://leetcode.com/problems/sqrtxip

三、题目内容leetcode

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

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

四、解题方法1数学

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

/**
 * 功能说明: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);
    }
}

五、解题方法2class

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

牛顿法开平方公式以下:

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

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

相关文章
相关标签/搜索