牛顿法求平方根

使用牛顿法求平方根的示意图如下:

求解某个数n的平方根可以看作是求方程的解。而方程即是上面图片中的二次曲线(蓝色),只要求出该二次曲线与x轴的交点x即求出了n的平方根。而牛顿法的思想就是通过迭代的方法不断逼近x。

首先取任意初值x0,则可以得到在二次曲线上对应于x0点的值y0和斜率,根据点(x0, y0)和斜率k可以求出过(x0, y0)的切线(红色)。可以看出相对于x0,切线与x轴的交点是x更好的一个近似。通过不断的重复该过程可以得到x值一个很好的近似,即求出了n的平方根。

很容易求出过点(x0, y0)斜率为k的直线方程为:,那该直线与x轴的交点x1为:,带入实际的值为:。现在我们就求出了从xn到xn+1的递推公式,只要设置好结束条件,即可求出x的近似值,也就是n平方根的近似值!

下面是根据牛顿法就n的平方根的C++程序:

#include <iostream>
#include <algorithm>

using namespace std;

double mySqrt(double n)
{
	double x = 1.0;
	while(abs(x * x - n) > 1e-9)
		x = (x + n / x) / 2;
	return x;
}

int main()
{
	cout << mySqrt(2) << endl;
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值