提示:注意实数的负零问题和误差问题。
关联习题:解一元一次方程。
所有实数均输出6位有效数字,且不输出末尾无意义的0和小数点。
#include <stdio.h>
#include <math.h>
int main()
{
float a,b,c,x,x1,x2,d;
scanf("%f,%f,%f",&a,&b,&c);
if(a==0){
if(b!=0){
x=-c/b;
printf("x = %g",x);
}
else if(a==0&&b==0&&c!=0){
printf("无解\n");
}
else if(a==0&&b==0&&c==0){
printf("无穷多解\n");
}
}
d=b*b-4*a*c;
if(a!=0&&d==0){
x1=(-b+sqrt(d))/(2*a);
x2=(-b-sqrt(d))/(2*a);
printf("x1 = x2 = %g",x2);
}
if(a!=0&&d>0){
x1=(-b+sqrt(d))/(2*a);
x2=(-b-sqrt(d))/(2*a);
printf("x1 = %g,x2 = %g",x1,x2);
}
if(a!=0&&d<0){
printf("x1 = %g + %.1fi\n",(-b)/(2*a),sqrt(-d)/(2*a));
printf("x2 = %g - %.1fi\n",(-b)/(2*a),sqrt(-d)/(2*a));
}
return 0;
}