输入一组数a,b,c
如果a的值足够小,接近于0,则输出不是二次方程的信息,并终止执行否则执行下一步
计算判别式△
计算p和q的值
p=-b/2*a
q=根号下△/2a
如果△的值足够小计算并输出两个相等的实根
如果为正计算并输出两个不等实根X1=p+q,X2=p-q
如果△的值为负计算并输出两个共轭复根 X1=p+qi X2=p-qi
#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#define EPS 1e-6
int main()
{
float a,b,c,disc,p,q;
scanf("%f%f%f",&a,&b,&c);
if(fabs(a)<=EPS)
{
printf("No\n");
exit(0);
}
disc=b*b-4*a*c;
if(fabs(disc<=EPS)
{
printf("x1=x2=%.2f\n",-b/(2*a));
}
else
{
p=-b/(2*a);
q=sqrt(fabs(disc))/(2*a);
if(dis>1e-6)
{
printf("Two:x1=%.2f,x2=%.2f\n",p+q,p-q);
}
else
{
printf("复数根")
printf("x1=%.2f+%.2fi\n",p,q);
printf("x2=%.2f-%.2fi\n",p,q);
}
}
return 0;
}