http://acm.ocrosoft.com/problem.php?id=1015
题目描述
求一元二次方程a*x2 + b*x + c = 0的根。系数a、b、c为浮点数,其值在运行时由键盘输入。须判定Δ(即三角形的判别式)的情形。
输入
有多组测试数据,每组测试数据有三个浮点数,分别为a,b,c。输入直到文件尾(!=EOF).
输出
每组测试数据输出一行。若有不同根,根按从大到小输出。相同根需输出两次。
样例输入
5 10 5
4 10 4
5.9 10 5.9
-5 -9 4
样例输出
the roots are -1.000000 and -1.000000
the roots are -0.500000 and -2.000000
delta is negative, no root.
the roots are 0.368858 and -2.168858
定义小数尽量使用double进行定义
#include <iostream>
#include <stdio.h>
#include <math.h>
#include <iomanip>
using namespace std; int main()
{
double a,b,c;
double n;
double x1,x2;
while(scanf("%lf%lf%lf",&a,&b,&c)!=EOF)
{
n=b*b-4*a*c;
x1=(-b-sqrt(n))/(2*a);
x2=(-b+sqrt(n))/(2*a);
cout<<setiosflags(ios::fixed)<<setprecision(6);
if(n<0)
cout<<"delta is negative, no root."<<endl;
else if(n>=0){ if(x1>=x2)
cout<<"the roots are "<<x1<<" "<<"and"<<" "<<x2<<endl;
else
cout<<"the roots are "<<x2<<" "<<"and"<<" "<<x1<<endl;
}
}
return 0;
}