求一元二次方程 ax 2 +bx+c=0 的解.保证有解 要求: 1. 判断是否有实根...
发布网友
发布时间:2024-10-08 05:55
我来回答
共1个回答
热心网友
时间:2024-10-27 16:20
参考代码如下:
#include<stdio.h>
#include<math.h>
int fun(double *x1, double *x2, double a, double b, double c)
{
double dt,absdt;
if(fabs(a)<1e-14)//解决浮点数比较误差的问题
return 0;//a为0时
dt=b*b-4*a*c;
absdt=fabs(dt);
if(absdt<1e-14){//解决浮点数比较误差的问题
*x1=*x2=-b/(2*a);//dt等于0时
return 1;
} else if(dt>0){
*x1=(-b+sqrt(dt))/(2*a);
*x2=(-b-sqrt(dt))/(2*a);
return 1;
} else return 0;
}
int main()
{
double a,b,c,x1,x2;
printf("输入a b c:\n");
do{
scanf("%lf%lf%lf",&a,&b,&c);
}while(fun(&x1,&x2,a,b,c)!=1);
printf("x1=%lf\n",x1);
printf("x2=%lf\n",x2);
}
热心网友
时间:2024-10-27 16:15
参考代码如下:
#include<stdio.h>
#include<math.h>
int fun(double *x1, double *x2, double a, double b, double c)
{
double dt,absdt;
if(fabs(a)<1e-14)//解决浮点数比较误差的问题
return 0;//a为0时
dt=b*b-4*a*c;
absdt=fabs(dt);
if(absdt<1e-14){//解决浮点数比较误差的问题
*x1=*x2=-b/(2*a);//dt等于0时
return 1;
} else if(dt>0){
*x1=(-b+sqrt(dt))/(2*a);
*x2=(-b-sqrt(dt))/(2*a);
return 1;
} else return 0;
}
int main()
{
double a,b,c,x1,x2;
printf("输入a b c:\n");
do{
scanf("%lf%lf%lf",&a,&b,&c);
}while(fun(&x1,&x2,a,b,c)!=1);
printf("x1=%lf\n",x1);
printf("x2=%lf\n",x2);
}