类Equation

建立一个类Equation,表达方程ax2+bx+c=0。类中至少包含以下方法:
1、无参构造(abc默认值为1、1、0)与有参构造函数,用于初始化a、b、c的值;
2、set方法,用于修改a、b、c的值
3、getRoot方法,求出方程的根。
一元二次方程的求根公式如下:

一元二次方程的求解分三种情况,如下:
在这里插入图片描述

输入

输入测试数据的组数t
第一组a、b、c
第二组a、b、c

输出

输出方程的根,结果到小数点后2位
在C++中,输出指定精度的参考代码如下:

#include
#include //必须包含这个头文件
using namespace std;
void main( )
{ double a =3.141596;
cout<<fixed<<setprecision(3)<<a<<endl; //输出小数点后3位

样例输入

3
2 4 2
2 2 2
2 8 2

样例输出

x1=x2=-1.00
x1=-0.50+0.87i x2=-0.50-0.87i
x1=-0.27 x2=-3.73

具体代码



#include<iostream>

#include<cmath>

#include<iomanip>

using namespace std;

 

class Equation

{

    double a, b, c,d;

    double x1, x2;

public:

    Equation();

    Equation(double a_value,double b_value,double c_value);

    double getA();

    double getB();

    double getC();

    void setA(double a_value);

    void setB(double b_value);

    void setC(double c_value);

    void getRoot(double x1,double x2,double x3);

};

Equation::Equation()

{

    a =
1;

    b =
1;

    c =
0;

}

Equation::Equation(double a_value, double b_value, double c_value) :a(a_value), b(b_value), c(c_value)

{

}

double Equation::getA()

{

    return a;

}

double Equation::getB()

{

    return b;

}

double Equation::getC()

{

    return c;

}

void Equation::setA(double a_value)

{

    a = a_value;

}

void Equation::setB(double b_value)

{

    b = b_value;

}

void Equation::setC(double c_value)

{

    c = c_value;

}

void Equation::getRoot(double x1, double x2,double x3)

{

    a = x1;

    b = x2;

    c=x3;

    d =
b * b - 4 * a*c;

    if (d > 0)

    {

         x1 = (-b + sqrt(d)) /
(2 * a);

         x2 = (-b - sqrt(d)) /
(2 * a);

         cout
<< fixed << setprecision(2)<<"x1=" << x1 << " " << "x2=" << x2 << endl;

    }

    if (d == 0)

    {

         x1 = x2 = (-b + d) / (2 *
a);

         cout
<< fixed << setprecision(2)<<"x1=x2=" << x1 << endl;

    }

    if (d < 0)

    {

         x1 = (-b) / (2 * a);

         x2 = sqrt(-d) / (2 *
a);

         cout
<< fixed<<setprecision(2)<<"x1="<<x1<<"+"<<x2<<"i" << " "<<"x2="<<x1<<"-"<<x2<<"i"<<endl;

    }

}

int main()

{

    int t;

    cin >> t;

    while (t--)

    {

         double a, b, c;

         cin
>> a >> b >> c;

         Equation text(a, b, c);

         text.getRoot(a,b,c);

    }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值