一、题目名称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