LeetCode——Sqrt(x)
2015-06-29 00:10
239 查看
Description:
Implement
Compute and return the square root of x.
好好学习数学还是非常有用的,牛顿迭代法 求解。
计算x2 = n的解,令f(x)=x2-n,相当于求解f(x)=0的解,如左图所示。
首先取x0,如果x0不是解,做一个经过(x0,f(x0))这个点的切线,与x轴的交点为x1。
同样的道理,如果x1不是解,做一个经过(x1,f(x1))这个点的切线,与x轴的交点为x2。
以此类推。
以这样的方式得到的xi会无限趋近于f(x)=0的解。
判断xi是否是f(x)=0的解有两种方法:
一是直接计算f(xi)的值判断是否为0,二是判断前后两个解xi和xi-1是否无限接近。
Implement
int sqrt(int x).
Compute and return the square root of x.
好好学习数学还是非常有用的,牛顿迭代法 求解。
计算x2 = n的解,令f(x)=x2-n,相当于求解f(x)=0的解,如左图所示。
首先取x0,如果x0不是解,做一个经过(x0,f(x0))这个点的切线,与x轴的交点为x1。
同样的道理,如果x1不是解,做一个经过(x1,f(x1))这个点的切线,与x轴的交点为x2。
以此类推。
以这样的方式得到的xi会无限趋近于f(x)=0的解。
判断xi是否是f(x)=0的解有两种方法:
一是直接计算f(xi)的值判断是否为0,二是判断前后两个解xi和xi-1是否无限接近。
public class Solution { public int mySqrt(int x) { if (x ==0) return 0; double pre; double cur = 1; do { pre = cur; cur = x / (2 * pre) + pre / 2.0; } while (Math.abs(cur - pre) > 0.00001); return (int) cur; } }
相关文章推荐
- 【Leetcode】Reversed Linked List
- UVA 550 Multiplying by Rotation (简单递推)
- Java基础:泛型及其擦除性、不可协变性
- hdu2005 关于输入的技巧及初始化问题
- 内存和FLASH的区别
- JavaScript写一个小乌龟推箱子游戏
- hadoop 流streaming跑python程序
- effective c++ 记录之对象切割问题
- 一个用 C 语言写的迷你版 2048 游戏,只有 500个字符
- SQL注入的攻击与防御(简单篇)
- C++标准异常类
- php页面静态化—触发系统生成纯静态化页面的三种方式
- The-Swift-2.0-Programming-Language-playground
- 收藏:Javascript 脚本的调试经验
- Java 容器
- 【吾日三省吾身】2015.6.28-涅槃行动第四十一天
- 如何从 Linux 上连接到远程桌面
- MAC 密钥散列算法
- Shell脚本实现的基于SVN的代码提交量统计工具
- ubuntu苹果主题