一、题目

编写程序求一个整数的平方根,精确到小数点后三位

二、解法

1) 采用 牛顿迭代法。

2)牛顿迭代法简介

假设方程 在  附近有一个根,那么用以下迭代式子:
                                         
       依次计算、……,那么序列将无限逼近方程的根。

牛顿迭代法的原理很简单,其实是根据f(x)在x0附近的值和斜率,估计f(x)和x轴的交点,看下面的动态图:

3)用牛顿迭代法开平方

令:                        
                  所以f(x)的一次导是 : 
                  牛顿迭代式:
                                              

随便一个迭代的初始值,例如,代入上面的式子迭代。

例如计算,即a=2:
                                
                                
                               

4)代码

import java.text.DecimalFormat;
import java.util.Scanner; /**
* 求平方根
*/
public class Sqr { public static void main(String[] args) {
// TODO 自动生成的方法存根
Scanner scan = new Scanner(System.in); DecimalFormat df = new DecimalFormat("#.000");
int sc = scan.nextInt();
System.out.print(sc + "的算术平方根是:");
System.out.println(df.format(SQR(sc)));
} public static double SQR(int a) {
double x1 = 1, x2;
x2 = x1 / 2.0 + a / (2 * x1);//牛顿迭代公式
while (Math.abs(x2 - x1) > 1e-4) {
x1 = x2;
x2 = x1 / 2.0 + a / (2 * x1);
}
return x2;
}
}

参考链接:

http://www.guokr.com/question/461510/

http://blog.csdn.net/guozhenqiang19921021/article/details/51284928

最新文章

  1. 【linux】进程不要开太多,否则系统会卡死!
  2. JavaScript Patterns 3.4 Array Literal
  3. 业务对象(BO)设计
  4. Scala语法笔记
  5. Redis 1:简介
  6. MySQL注入load_file常用路径
  7. 实测 windows下nginx很不稳定,换成squid好多了
  8. hdoj 1856 More is better【求树的节点数】
  9. ORACLE分科目统计每科前三名的学生的语句
  10. vue的测试(Vue.js devtool)
  11. python基础(9):文件处理
  12. C和C++中的名字空间和作用域
  13. mentohust 使用
  14. Gentoo(贱兔)Linux安装笔记
  15. windows下安装mysql以及启动
  16. 5. React 组件的协同使用 组件嵌套和Mixin
  17. Django的forms表单组件批量设置字段样式
  18. NOIP 2018 游记(退役了!)
  19. 更有效率的使用Visual Studio
  20. Fluent Python: Slice

热门文章

  1. c++中typedef、define、const、inline之间的区别
  2. sql计算经纬度得出最近距离的公式
  3. python处理中文
  4. Linux远程批量工具mooon_ssh和mooon_upload使用示例
  5. 1109 Group Photo
  6. (DP 雷格码)Gray code -- hdu -- 5375
  7. PHP搜索 搜索 搜索
  8. 初始Yarn
  9. SRM484
  10. appcompat_v7报错