早教吧 育儿知识 作业答案 考试题库 百科 知识分享

写出用二分法求方程x^3-x-1=0在区间[1,1.5]上的一个解的算法误差不超过0.001并画出程序框图及程序\x0c越...写出用二分法求方程x^3-x-1=0在区间[1,1.5]上的一个解的算法误差不超过0.001并画出程序框

题目详情
写出用二分法求方程x^3-x-1=0在区间[1,1.5]上的一个解的算法误差不超过0.001并画出程序框图及程序\x0c越...
写出用二分法求方程x^3-x-1=0在区间[1,1.5]上的一个解的算法误差不超过0.001并画出程序框图及程序\x0c越快越好要过程速度拜托
▼优质解答
答案和解析
#include
#include
double fx(double a,double b,double c,double d,double x1,double x2,double f1,double f2)
{
\x09double x0,f;
\x09while(fabs(f)>1e-6)
\x09{
\x09\x09x0=(x1+x2)/2;
\x09\x09f=a*pow(x0,3)+b*x0*x0+c*x0+d;
\x09\x09if(f1*f>0)
\x09\x09{\x09
\x09\x09\x09x1=x0;
\x09\x09\x09f1=f;
\x09\x09}
\x09\x09else
\x09\x09{\x09
\x09\x09\x09x2=x0;
\x09\x09\x09f2=f;
\x09\x09}
\x09 }
\x09 return x0;
}
void main()
{
\x09double a,b,c,d,x,x1,x2,f1,f2;
\x09printf("请输入方程系数 a,b,c,d:\n");
\x09scanf("%lf,%lf,%lf,%lf",&a,&b,&c,&d);
\x09printf("请输入区间[x1,x2]\n");
\x09scanf("%lf,%lf",&x1,&x2);
\x09f1=a*pow(x1,3)+b*x1*x1+c*x1+d;
\x09f2=a*pow(x2,3)+b*x2*x2+c*x2+d;
\x09if(f1*f2>0)
\x09{
\x09\x09printf("该区间内方程无解\n");
\x09}
\x09else
\x09{
\x09\x09x=fx(a,b,c,d,x1,x2,f1,f2);
\x09\x09printf("方程解为x=%lf\n",x);
\x09}
}
程序适合a*x^3+b*x^2+c*x+d=0,精度也很高,修改下就行