牛頓迭代法求解方程的根
引題:用牛頓迭代法求下列方程在值等於x附近的根:
2x3−4x2+3x−6=0
輸入:輸入x。
輸出:方程在值等於x附近的根,占1行。
輸入示例:1.5
輸出實例:2
1. 牛頓迭代公式推導
設多項式
f(x),設r是
f(x)的根。
選取
x0作為r的初始近似值。
過點
(x0,f(x0))做曲線
y=f(x)的切線L。得L:
y=f(x0)+f′(x0)(x−x0)
則L與x軸交點的橫坐標為
x1=x0−f′(x0)f(x0),那么稱
x1為r的一次近似值。
過點
(x1,f(x1))做曲線
y=f(x)的切線,並求該切線與x軸交點的橫坐標
x2=x1−f′(x1)f(x1),稱
x2為r的二次近似值。
重復以上過程,得r的近似值序列。
其中,
xn+1=xn−f′(xn)f(xn)稱為r的n+1次近似值。
所以,
xn+1=xn−f′(xn)f(xn)即為牛頓迭代公式。
2. 牛頓迭代公式核心思想
核心思想:使用泰勒級數的線性項近似計算函數
f(x)=0的根。把
f(x)在點
x0的某領域內展開成泰勒級數,取其線性部分(即泰勒展開的前兩項),並令其等於0。
泰勒級數展開式:
f(x)=f(x0)+f′(x0)(x−x0)+2!f′′(x0)(x−x0)2+…+n!f(n)(x0)(x−x0)n+Rn(x)
線性部分:
f(x)=f(x0)+f′(x0)(x−x0)
令其為0,並以此作為非線性方程
f(x)=0的近似方程,即切線方程,得到公式:
x=x0−f′(x)f(x)
將其推廣,即可以得到牛頓迭代公式:
xn+1=xn−f′(xn)f(xn)
#include <iostream>
#include <cmath>
using namespace std;
double f(double x)
{
return 2*pow(x,3)-4*pow(x,2)+3*x-6;
}
double f1(double x)
{
return 6*pow(x,2)-8*x+3;
}
int main()
{
float x;
cin >> x;
do
{
x = x - f(x)/f1(x);
}while( f(x)>1e-5 || f(x)<-(1e+5) );
cout << x << endl;
}