已知A,B,C的值,求根的个数....
讨论一下系数的情况即可...
Description
You are given an equation:
Your task is to find the number of distinct roots of the equation and print all of them in ascending order.
Input
The first line contains three integer numbers A, B and C ( - 105 ≤ A, B, C ≤ 105). Any coefficient may be equal to 0.
Output
In case of infinite root count print the only integer -1. In case of no roots print the only integer 0. In other cases print the number of root on the first line and the roots on the following lines in the ascending order. Print roots with at least 5 digits after the decimal point.
Sample Input
Input
1 -5 6
Output
2 2.0000000000 3.0000000000
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
double sqrtt(double x)
{
if(x<0) return -sqrt(-x);
else return sqrt(x);
}
int main()
{
double a,b,c;
double x1,x2;
while(cin>>a>>b>>c) {
if(a==0&&b==0) {
if(c==0) printf("-1\n");
else printf("0\n");
}
else if(a==0&&c==0) {
printf("1\n0\n");
}
else if(b==0&&c==0) {
printf("1\n0\n");
}
else if(a==0) {
printf("1\n");
printf("%.6lf\n",-c/b);
}
else {
double tem=b*b-4*a*c;
if(tem<0) printf("0\n");
else if(tem==0) {
printf("1\n");
printf("%.6lf\n",(-b/(2*a)));
}
else {
printf("2\n");
x1=(-b-sqrtt(tem))/(2*a);
x2=(-b+sqrtt(tem))/(2*a);
if(x1>x2) swap(x1,x2);
printf("%.6lf\n%.6f\n",x1,x2);
}
}
}
return 0;
}