SDUSTOJ Problem F: 一元二次方程类
来源:互联网 发布:mac应用程序文件夹 编辑:程序博客网 时间:2024/05/22 05:28
Description
定义一个表示一元二次方程的类Equation,该类至少具有以下3个数据成员:a、b和c,用于表示方程“a*x*x + b*x +c = 0”。同时,该类还至少具有以下两个成员函数:
1. void solve():用于求方程的根。
2. void printRoot():用于输出方程的根。
设定:
1. 所有输入的a、b、c所生成的方程必定有个2个不同的实根。
2. 输出的两个根按照从大到小的顺序输出,两个根之间用一个空格隔开,而且每个根必须且仅能保留2位小数,即使小数部分为0。
3. 请根据样例和给出的main()函数定义相应的构造函数。
Input
输入有若干行,每行有3个实数,分别为方程“a*x*x + b*x + c = 0”中的系数a、b、c。
Output
按照题目要求中的设定条件2输出方程的根。
Sample Input
1 3 2
Sample Output
-1.00 -2.00
HINT
可以使用fixed和setprecision()来实现输出固定小数位数的数值。
Append Code
append.cc,
#include<iostream>#include<iomanip>#include<cmath>using namespace std;class Equation{private: double a; double b; double c; double s1; double s2;public: Equation(double x,double y,double z):a(x),b(y),c(z){} void solve() { s1=(-b+sqrt(b*b-4*a*c))/(2*a); s2=(-b-sqrt(b*b-4*a*c))/(2*a); } void printRoot() { cout <<setiosflags(ios::fixed); cout<<setprecision(2)<<max(s1,s2)<<" "<<min(s1,s2)<<endl; }};int main(){ double a, b, c; while (cin>>a>>b>>c) { Equation equ(a,b,c); equ.solve(); equ.printRoot(); } return 0;}
0 0
- SDUSTOJ Problem F: 一元二次方程类
- Problem A: 一元二次方程类
- Problem B: 一元二次方程类
- Problem B: 一元二次方程类
- Problem C: 一元二次方程类
- Problem C: 一元二次方程类
- Problem C: 一元二次方程类
- Problem F: C语言实验——一元二次方程Ⅰ
- 一元二次方程
- 一元二次方程
- 一元二次方程
- 一元二次方程
- 一元二次方程
- 一元二次方程
- 一元二次方程
- 一元二次方程
- 一元二次方程
- 一元二次方程
- libmysql
- PAT (Advanced Level) Practise 1049 Counting Ones (30)
- UVA10700求只有加法和减法的表达式的最大值和最小值
- snvserve不是内部命令
- 第三周项目2 本月有几天?
- SDUSTOJ Problem F: 一元二次方程类
- 写给2017年的自己
- mysql的多个问题
- 内部类的理解
- Linux Bridge
- mysql问题汇总
- final关键字总结
- SDUSTOJ Problem G: 整数的封装(该题目要注意尽量不要使用pow函数)
- 完全极大极小搜索题集