用迭代法怎么解一元三次方程(数值分析的题)?

百度网友5cf34f662
2007-12-21 · TA获得超过1168个赞
知道答主
回答量:276
采纳率:0%
帮助的人:0
展开全部
牛顿迭代法是牛顿在17世纪提出的一种求解方程f(x)=0.多数方程不存在求根公式,从而求精确根非常困难,甚至不可能,从而寻找方程的近似根就显得特别重要。 设r是f(x)=0的根,选取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},其中Xn+1=Xn-f(Xn)/f'(Xn),称为r的n+1次近似值。上式称为牛顿迭代公式。
/*用牛顿迭代法求下面方程 x*x*x-5*x*x+16*x-80=0的实根的过程是:1.你想在谁附近求解,这个范围或者这个数值大多是题目已经给定了的(本例是根据输入的数值来计算的)2.令f(x)=x*x*x-5*x*x+16*x-803.x1=X4.求f(x1)5.对f(x)求导,得到f1(x),求f1(x1)6.调整x,使x=x1-f(x1)/f1(x1) 7.符合条件x-x1>1e-5,转到第3步8.不符合条件x-x1>1e-5,则x1就是我们要求的实根*/#include <stdio.h>#include <math.h>//y=((x-5)*x+16)*x-80
float f(float x){ return (pow(x,3)-5*pow(x,2)+16*x-80);}
float f1(float x){ return (3*pow(x,2)-10*x+16);}void main(){ float x,x1,y1,y2; printf("请输入一个任意实数:X="); scanf("%f",&x); printf("我可以帮你找到这个方程的解\n"); do { x1=x; y1=f(x); y2=f1(x1); x=x1-y1/y2; } while (fabs(x-x1)>=1e-5); printf("A root is %f\n",x1);}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式