C语言:求一元二次方程ax^2+bx+c=0的解,要求用函数调用来完成,
其中a,b,c的值从主函数中输入,有两个解输出这两个解,有相等的解输出相等的解,无解则输出无解。求指导,谢谢。。。...
其中a,b,c的值从主函数中输入,有两个解输出这两个解,有相等的解输出相等的解,无解则输出无解。
求指导,谢谢。。。 展开
求指导,谢谢。。。 展开
2个回答
展开全部
解一元二次方程,C语言函数实现,参考代码如下:
#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);
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");
scanf("%lf%lf%lf",&a,&b,&c);
if(fun(&x1,&x2,a,b,c)==1){
printf("x1=%lf\n",x1);
printf("x2=%lf\n",x2);
}else
printf("无解");
return 0;
}
#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);
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");
scanf("%lf%lf%lf",&a,&b,&c);
if(fun(&x1,&x2,a,b,c)==1){
printf("x1=%lf\n",x1);
printf("x2=%lf\n",x2);
}else
printf("无解");
return 0;
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询