用二分法解一元三次方程的C++程序
武汉大学考试中心-加工合同范本
#include
#include
void main()
{
double x0,x1,xm,f0,f1,f
m,x2,x3;x2,x3是驻点,x0,x1,xm,f0,x1是二分法求根的工具。
double a[3],r[3];
int i,j=0;
printf(
for(i=0;i<3;i++)
{
printf(
scanf(
}
printf(
printf(
y=3*x*x+2*a[0]*x+a[1]
if(4*a[0]*a[0]-12*a[1]<0)方程单调递增,与横轴只有一个交点。
{
printf(
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
if(f0*f1==0)
{
if(f0==0)
{
xm=x0;
printf(
}
else
{
xm=x1;
printf(
}
if(fabs(xm*xm*xm+a[0]*xm*xm+a[1]*xm+a[2])<1e-6)
printf(
else
printf(
}
else
{
while(f0*f1>=0)
{
printf(
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
}
do
{
xm=(x0+x1)2;
fm=xm*xm*xm+a[0]*xm*xm+a[1]*xm+a[2];
if(f0*fm>0)
x0=xm;
else
x1=xm;
}while(fabs(x0-x1)>1e-6);
xm=(x0+x1)2;
printf(
if(fabs(xm*xm*xm+a[0]*xm*xm+a[1]*xm+a[2])<1e-6)
printf(
else
printf(
}
}
else方程有增有减,但与横轴的交点不确定。
{
x2=(-2*a[0]-sqrt(4*a[0]*a[0]-12*a[1]))6;
x3=(-2*a[0]+sqrt(4*a[0]*a[0]-12*a[1]))6;
printf(
printf(
if((x2*x2*x2+a[0]*x2*x2+a[1]*x2+a[2])>0&&(x3*x3*x3
+a[0]*x3*x3+a[1]*x3+a[2])>0)
方程左半单调递增支和横轴有交点。
{
printf(
and the
other should be smaller than x2. you will get just
one root.n
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
while(f0*f1>=0)
{
printf(
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
}
do
{
xm=(x0+x1)2;
fm=xm*xm*xm+a[0]*xm*xm+a[1]*xm+a[2];
if(f0*fm>0)
x0=xm;
else
x1=xm;
}while(fabs(x0-x1)>1e-6);
xm=(x0+x1)2;
printf(
if(fabs(xm*xm*xm+a[0]*xm*xm+a[1]*xm+a[2])<1e-6)
printf(
else
printf(
}
else
if((x2*x2*x2+a[0]*x2*x2+a[1]*x2+a[
2])<0&&(x3*x3*x3+a[0]*x3*x3+a[1]*x3+a[2])<0)
方程右半单调递增支和横轴有交点
{
printf(
and the
other should be bigger than will get just one
root.n
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
while(f0*f1>=0)
{
printf(
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
}
do
{
xm=(x0+x1)2;
fm=xm*xm*xm+a[0]*xm*xm+a[1]*xm+a[2];
if(f0*fm>0)
x0=xm;
else
x1=xm;
}while(fabs(x0-x1)>1e-6);
xm=(x0+x1)2;
printf(
if(fabs(xm*xm*xm+a[0]*xm*xm+a[1]*xm+a[2])<1e-6)
printf(
else
printf(
}
else
if((x2*x2*x2+a[0]*x2*x2+a[1]*
x2+a[2])*(x3*x3*x3+a[0]*x3*x3+a[1]*x3+a[2])<0)一般方程
有三个交点,分别位于增、减、增区间。
{
printf(will
get 3 roots, type in 2 numbers 3 times, and in the
first case, the
bigger number you type in
should be x2; and in the second case, the 2
numbers you type in should
be x2 and x3, and
in the third case, the smaller one should be
x3.n
for(i=0;i<3;i++)
{
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
while(f0*f1>=0)
{
printf(
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
}
do
{
xm=(x0+x1)2;
fm=xm*xm*xm+a[0]*xm*xm+a[1]*xm+a[2];
if(f0*fm>0)
x0=xm;
else
x1=xm;
}while(fabs(x0-x1)>1e-6);
r[i]=(x0+x1)2;
printf(
}三次循环找三个根。
printf(
for(i=0;i<3;i++)
printf(
for(i=0;i<3;i++)
if(fabs(r[i]*r[i]*r[i]+a[
0]*r[i]*r[i]+a[1]*r[i]+a[2])<1e-6)
j++;
if(j==3)
printf(
else
printf(
}
else
{
if(x2*x2*x2+a[0]*x2*x2+a[1]*x2+
a[2]==0&&x3*x3*x3+a[0]*x3*x3+a[1]*x3+a[2]!=0)x2
是一个二重根
{
r[0]=r[1]=x2;
补充剩下的
printf(
be x3, and the other
should be bigger than will get just one
root.n
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
while(f0*f1>=0)
{
printf(
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
}
do
{
xm=(x0+x1)2;
fm=xm*xm*xm+a[0]*xm*xm+a[1]*xm+a[2];
if(f0*fm>0)
x0=xm;
else
x1=xm;
}while(fabs(x0-x1)>1e-6);
r[2]=(x0+x1)2;
printf(
for(i=0;i<3;i++)
printf(
for(i=0;i<3;i++)
if(fabs(r[i]*r[i]*r[i
]+a[0]*r[i]*r[i]+a[1]*r[i]+a[2])<1e-6)
j++;
if(j==3)
printf(
else
printf(
}
else
if(x2*x2*x2+a[0]*x2*x2+a[
1]*x2+a[2]!=0&&x3*x3*x3+a[0]*x3*x3+a[1]*x3+a[2]==0
)
{
r[0]=r[1]=x3;
补充剩下的
printf(
be x2, and the other should be
smaller than will get just one root.n
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
while(f0*f1>=0)
{
printf(
printf(
scanf(
printf(
scanf(
f0=x0*x0*x0+a[0]*x0*x0+a[1]*x0+a[2];
f1=x1*x1*x1+a[0]*x1*x1+a[1]*x1+a[2];
}
do
{
xm=(x0+x1)2;
fm=xm*xm*xm+a[0]*xm*xm+a[1]*xm+a[2];
if(f0*fm>0)
x0=xm;
else
x1=xm;
}while(fabs(x0-x1)>1e-6);
r[2]=(x0+x1)2;
printf(
for(i=0;i<3;i++)
printf(
for(i=0;i<3;i++)
if(f
abs(r[i]*r[i]*r[i]+a[0]*r[i]*r[i]+a[1]*r[i]+a[2])<
1e-6)
j++;
if(j==3)
printf(
else
printf(
}
else
{
r[0]=r[1]=r[2]=x2;
printf(
printf(
for(i=0;i<3;i++)
printf(
for(i=0;i<3;i++)
if(fabs(r[i]*r[i]*r[i]+a
[0]*r[i]*r[i]+a[1]*r[i]+a[2])<1e-6)
j++;
if(j==3)
printf(
else
printf(
}
}
}
}