用牛顿迭代求方根

项目github地址:bitcarmanlee easy-algorithm-interview-and-practice
欢迎大家star,留言,一起学习进步

1.前言

各种编程语言中都有实现求一个数方根的函数,即sqrt函数。但是,如果不用sqrt函数,只用四则运算让求一个数的方根,该怎么办勒?换句话说,让你自己实现sqrt函数,你能实现么?OK,各位最好先自己想想然后动手实现以下。如果遇到了困难,欢迎接着往下阅读本文。

2.用二分的思想

二分法是非常好用的套路。对于各种快速查找还有迭代类的运算都是一把好手。而且复杂度只有 log ⁡ n \log n logn。这里我们也可以采用类似的思路进行计算:假设一个start,一个end,假设最终方根值为result,初始值取 n / 2 n/2 n/2。然后根据result平方和与n的差的大小进行比较,更新start与end,最后求出结果。
直接上源码:

public class Root_Of_Num {

    public static double bin_sec_root(int n) {
        double start = 0;
        double end = n / 2.0;
        double result = n / 2.0;
        double eps = 0.00001; //精度

        double tmp = result * result - n;

        if (tmp < eps) {
            return result;
        }

        while (Math.abs(tmp) > eps) {
            if (tmp > 0) {
                end = result; //更新end 
                result = (start + result) / 2;
            } else {
                start = result; //更新start
                result = (result + end) / 2;
            }
            tmp = result * result - n;
        }

        return result;
    }
    
    public static void main(String[] args) {
        int n = 5;
        double result = bin_sec_root(n);
        System.out.println("result is: " + result);
    }
}

各位亲,是不是跟二分的思路很像?

3.用牛顿迭代

其实,更快的一种方式是用牛顿迭代的方法。关于牛顿迭代,以后会写专门的文章给大家介绍。先上代码:

public class Root_Of_Num {
    public static double newton_iteration_root(int n) {
        double result = 1.0; //迭代初始值
        double eps = 0.00001;
        double tmp = result*result - n;

        while(Math.abs(tmp) > eps) {
	        //牛顿迭代公式
            result = 0.5 * (result + (n / result));
            tmp = result*result - n;
        }
        return result;
    }
    public static void main(String[] args) {
        int n = 5;
        double result = newton_iteration_root(n);
        System.out.println("result is: " + result);
    }
}

这里面最关键的一行其实就是迭代公式那行。要明白为什么这样迭代就能求出方根,需要有相应的数学知识作为基础。请同学们参考我有关牛顿迭代,泰勒展开的文章:http://blog.csdn.net/bitcarmanlee/article/details/52195617
牛顿迭代的速度也很快,一般迭代6-7次,就能得到精度相当高的结果!
最后不禁感叹,数学的力量是伟大的。一切的自然科学,都离不开数学的神奇魔力。只有数学好,才是真的好!

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值