迭代法編程c
發布時間: 2025-05-15 04:58:01
Ⅰ C語言編程中用牛頓迭代法求解方程
#include<stdio.h>
#include<math.h>
int main()
{
float x1,x,f1,f2;static int count=0;
x1=1.5//定義初始值
do
{
x=x1;
f1=x*(2*x*x-4*x+3)-6;
f2=6*x*x-8*x+3;//對函數f1求導
x1=x-f1/f2; count++;
}while(fabs(x1-x)<=1e-5);
printf("%8.7f\n",x1); printf("%d\n",count);
return 0;
}
//2x3-4x2+3x-6//根據我改了初始值,查看結果,表明:改變初始值得到的結果並不一樣,但是迭代的次數並沒有改變!!
Ⅱ C語言編程:牛頓迭代法求方程的根
程序流程分析:
① 賦值x0=1.5,即迭代初值;
② 用初值x0代入方程中計算此時的f(x0)及f』(x0),程序中用變數f描述方程的值,用fd描述方程求導之後的值;
③ 計算增量d=f/fd;
④ 計算下一個x,x=x0-d;
⑤ 把新產生的x替換x0,為下一次迭代做好准備;
⑥ 若d絕對值大於1e-3,則重復②③④⑤步。
源程序代碼:
#include <math.h>
main()
{
float x,x0,d,f,fd;
x0=0;
do {
f=2*x0*x0*x0-4*x0*x0+3*x0-6;
fd=6*x0*x0-8*x0+3;
d=f/fd;
x=x0-d;
x0=x;
}while(fabs(d)>1e-3);
printf("x=%f\n",x);
}
熱點內容