给定一元二次方程的三个系数,求方程的根。
Input有多组数据。每组数据由三个双精度数组成,分别表示一元二次方程的三个系数。
Output
方程的根。如果二次项的系数为0,则输出“not a quadric equation!”。
尽可能使用函数、指针和结构
程序代码:#include<stdio.h>
#include<math.h>
int main()
{double a,b,c,s,p,q,x1,x2;
scanf("a=%lf,b=%lf,c=%lf",&a,&b,&c);
if(b==0)
{printf("not a quadric equation!\n");}
if(b!=0)
{s=b*b-4*a*c;
p=-b/(2*a);
q=sqrt(s)/(2*a);
x1=p+q;
x2=p-q;
if(x1!=x2)
printf("方程的解为:x1=%5.2f,x2=%5.2f\n",x1,x2);
if(x1==x2)
printf("方程的解为:x1=x2=%5.2f\n",x1);}
return 0;
}