超时限制:1000ms
内存限制:65535kb
题目描述给出一个形如Ax^2+Bx+C=0的式子,问有多少个解。
输入格式:第一行:三个**整数**表示上式的A、B、C($-1e5\leqslant A,B,C\leqslant1e5$)
输出格式:第一行:一个整数,表示解的个数,如果有无数个解,请输出-1。
接下来若干行:每行一个解,请按大小顺序输出。(保留6位小数)
输入样例:1 -5 6
输出样例:
2
2.000000
3.000000
参考程序:
#include<stdio.h>
#include<math.h>
#include<stdlib.h>
using namespace std;
int main()
{
long long a,b,c;
scanf("%lld%lld%lld",&a,&b,&c);
if(a==0&&b==0&&c==0)
printf("%d",-1);
else if(a==0&&b==0&&c!=0)
printf("%d",0);
else if(a==0&&b!=0)
printf("1\n%.6lf",-double(c)/b);
else
{
if(b*b-4*a*c<0)
printf("0");
else if(b*b-4*a*c==0)
{
printf("1\n");
double x=double(-b)/2/a;
printf("%.6lf",x);
}
else
{
printf("2\n");
double x1=double(-b+sqrt(b*b-4*a*c))/2/a;
double x2=double(-b-sqrt(b*b-4*a*c))/2/a;
double t;
if(x1>x2)
t=x1,x1=x2,x2=t;
printf("%.6lf\n%

最低0.47元/天 解锁文章
358

被折叠的 条评论
为什么被折叠?



