C语言编程——内容:用牛顿迭代法求一元三次方程的根.要求:由主函数调用求根子函数,谢谢各位了
人气:324 ℃ 时间:2020-04-24 20:30:22
解答
牛顿迭代法
牛顿迭代法又称牛顿切线法,它采用以下方法求根:先任意设定一个与真实的根接近的值x0作为第一个近似根,由x0求出f(x0),过(x0,f(x0))点做f(x)的切线,交x轴于x1,把它作为第二次近似根,再由x1求出f(x1),再过(x1,f(x1))点做f(x)的切线,交x轴于x2,再求出f(x2),再作切线……如此继续下去,直到足够接近真正的x为止.
其中f'(X0)是函数在X0处的斜率,也就是在X0处的导数.
代码如下:
#include
#include
float f(float a,float b,float c,float d,float x)
{
float f;
f=((a*x+b)*x+c)*x+d;
return f;
}
float f1(float a,float b,float c,float x)
{
float f;
f=(x*3*a+2*b)*x+c;
return f;
}
float root(float a,float b,float c,float d)
{
float x0,x1=1;
do
{
x0=x1;
x1=x0-f(a,b,c,d,x0)/f1(a,b,c,x0);
}while(fabs(x1-x0)>=1e-6);
return x0;
}
void main()
{
float a,b,c,d,x;
printf("input four float numbers:\n");
scanf("%f%f%f%f",&a,&b,&c,&d);
x=root(a,b,c,d);
printf("%.1fX^3+%.1fX^2+%.1fX+%.1f=0 its root near x=1.5 is :%.4f\n",a,b,c,d,x);
getch();
}
推荐
- C语言编程:牛顿迭代法求方程的根
- 利用函数完成用牛顿迭代法求根.方程为ax3+bx2+cx+d=0,系数a、b、c、d的值依次为1,2,3,4,有主函数输入.求x在1附近的一个实根.求出根后由主函数输出.
- 编写一函数实现用牛顿迭代法求方程ax3+bx2+cx+d=0在x=1附近的一个实根.主函
- 用C语言编程求牛顿迭代法求方程f(x)=0的根.(
- I don't think Chinese is ( ) maths.A.as easy as B.easier than 为什么选A?要理由.
- 四边形ABCD中,AB∥CD,且AB、CD长是关于x的方程x2-3mx+2m2+m-2=0的两个实数根,则四边形ABCD是( ) A.矩形 B.平行四边形 C.梯形 D.平行四边形或梯形
- 做一件工作,单独做甲要15天,乙要20天,现由甲先做5天后,由乙接着做,还需几天完成这批工作?
- 白领小张每月投资1万元,平均报酬率为6%,那么10年后累计收入为多少元?能写出具体公式吗
猜你喜欢
- 30分钟走了全程的1/6,50分钟走全程的几分之几 30分钟走了全程的1/6,50分钟走全程
- 1.把一个高3分米的圆柱的底面平均分成若干个扇形,然后把圆柱切开,拼成一个与它等底等高的近似长方体,长方体的表面积比圆柱的表面积多120平方厘米.原来圆柱的体积是多少?
- on hearing the shoking news my heart broke,immed
- 一件西服,促销期间打八折出售,现价为180元,现价比原价降低了多少元?
- 一只漏水的船,当发现漏水时已经进了一些水,水均速进入船内,如果21人淘水,8小时
- 为了测定赤铁矿中二氧化三铁的纯度,采集20g样品放入烧杯中,加入盐酸,完全反应
- ABCC型的四字成语!马上要交!
- 写一篇关于《我爱家乡的雪》的作文