C ++二次方程式求解器-错误的虚解

时间:2018-07-08 01:12:16

标签: c++ c++11 computer-science program-structure

正如标题所述,每当我在二次方程求解器中输入导致虚解的某些数字时,我就无法表达适当的虚解。

我尝试过的一些事情包括创建一个新的强制转换变量,该变量基本上是判别式的绝对值,但是是一个全新的变量。

此外,我尝试将判别变量本身与abs()函数一起使用,并且将绝对值乘以负值。

我非常感谢您的投入。如果你们需要它,这是我的代码。

编辑:如果您想知道我输入的某些值,则输入2,-5和4作为A,B和C。如果要检查计算器/二次求解器,则该值应在1.25 +-0.66I,但我得到了3.00 * I和-0.5 * I。

#include <iostream>
#include <cmath>
#include <string>
#include <iomanip>
using namespace std;

int main() {

    cout << fixed << scientific << setprecision(5);
    cout << setfill('*') << setw(61) << '*' << endl;
    cout << "5Chan Christina Quadratic Equation Solver" << endl;
    cout << setfill('*') << setw(61) << '*' << endl;

    cout<< "Welcome to Quadratic Equation Solver, where we will input solutions from your inputs based on the form" << endl;
    cout << setw(31) << "Ax^2 + Bx + C = 0" << endl;
    cout << "Where A, B, and C are integers, and A is not equal to zero." << endl;
    cout << setfill('*') << setw(61) << '*' << endl;

    int A, B, C;


// discriminant program



// The following equations represent both
//parts of the quadratic equation, converted to double form


    cout << "Enter the input for A. " << endl;
    cin >> A;

    if (A == 0)
/* Here, when A == 0
The following statements are executed under such subconditions
*/
    {
        cout << "Warning, any more 0 input will not produce any equation!" << endl;
        cout << "Enter the input for B. " << endl;
        cin >> B;
        if (B == 0)
        {
            cout << "Invalid! Start over! You do not have an algebraic equation!" << endl;
            cout << setfill('*') << setw(61) << '*' << endl;
            cout << "Thank you for using Quadratic Equation Solver!" << endl;
            cout << setfill('*') << setw(61) << '*' << endl;
        }

        // tfw your input results in a linear equation...
        else if (B != 0)
        {
            cout << "Enter the input for C. " << endl;
            cin >> C;
            double lin_eq = static_cast<double>(-C)/B; 
            // linear equation form when b is NOT 0
            cout << "Solution is " << endl;
            cout << setw(50) << lin_eq << endl;
            cout << setfill('*') << setw(61) << '*' << endl;
            cout << "Thank you for using Quadratic Equation Solver!" << endl;
            cout << setfill('*') << setw(61) << '*' << endl;
        }
    }

else //basically, when A is NOT zero
{

    cout << "Enter the input for B. " << endl;
    cin >> B;   
    cout << "Enter the input for C. " << endl;
    cin >> C;

    double disc = static_cast<double>((B*B)-(4*A*C));
    double quad_1 = static_cast<double>((-B) + sqrt((B*B) - (4*A*C)))/(2*A);
    double quad_2 = static_cast<double>((-B) - sqrt((B*B) - (4*A*C)))/(2*A);


    if (disc > 0) // discriminant greater than 0
    // 2 solutions are printed 
    {
        cout << "The two real solutions are" << setw(31) << quad_1 << endl;
        cout << setw(20) << "and" << setw(51) << quad_2;
        cout << setfill('*') << setw(61) << '*' << endl;
        cout << "Thank you for using Quadratic Equation Solver!" << endl;
        cout << setfill('*') << setw(61) << '*' << endl;
    }

    else if (disc == 0) 
    {
            cout << "Solution is " << endl;
            cout << setw(50) << quad_2 << endl;
            cout << setfill('*') << setw(61) << '*' << endl;
            cout << "Thank you for using 5Chan Christina Quadratic Equation Solver!" << endl;
            cout << setfill('*') << setw(61) << '*' << endl;



    }       

    else if (disc < 0) // This segment of code 
    // Prints imaginary values through discriminant abs value
    {

        double imag_help =  static_cast<double>(abs(disc));
      double imag_solution_1 = ((-B+imag_help)/(2*A));
      double imag_solution_2 = ((-B-imag_help)/(2*A));
      cout << "The two imaginary solutions ARE" << setw(31) << "x= " << imag_solution_1 << "*I" << endl;
      cout<< setw(15) << " AND "  << setw(31) << "x=" << imag_solution_2 << "*I" << endl;
      cout << setfill('*') << setw(61) << endl;
      cout << "Thank you for using Quadratic Equation Solver." << endl;
      cout << setfill('*') << setw(61) << endl;




    }




}

}

1 个答案:

答案 0 :(得分:1)

尝试一下。您的问题在于假想数学。您正在添加/减去实部和虚部。你不能那样做。我在虚构部分重用了您的两个变量。 imag_solution_1现在是实部,而imag_solution_2现在是虚部。

#include <iostream>
#include <cmath>
#include <string>
#include <iomanip>
using namespace std;

int main() {

    cout << fixed << scientific << setprecision(5);
    cout << setfill('*') << setw(61) << '*' << endl;
    cout << "5Chan Christina Quadratic Equation Solver" << endl;
    cout << setfill('*') << setw(61) << '*' << endl;

    cout << "Welcome to Quadratic Equation Solver, where we will input solutions from your inputs based on the form" << endl;
    cout << setw(31) << "Ax^2 + Bx + C = 0" << endl;
    cout << "Where A, B, and C are integers, and A is not equal to zero." << endl;
    cout << setfill('*') << setw(61) << '*' << endl;

    int A, B, C;


    // discriminant program



    // The following equations represent both
    //parts of the quadratic equation, converted to double form


    cout << "Enter the input for A. " << endl;
    cin >> A;

    if (A == 0)
        /* Here, when A == 0
        The following statements are executed under such subconditions
        */
    {
        cout << "Warning, any more 0 input will not produce any equation!" << endl;
        cout << "Enter the input for B. " << endl;
        cin >> B;
        if (B == 0)
        {
            cout << "Invalid! Start over! You do not have an algebraic equation!" << endl;
            cout << setfill('*') << setw(61) << '*' << endl;
            cout << "Thank you for using Quadratic Equation Solver!" << endl;
            cout << setfill('*') << setw(61) << '*' << endl;
        }

        // tfw your input results in a linear equation...
        else if (B != 0)
        {
            cout << "Enter the input for C. " << endl;
            cin >> C;
            double lin_eq = static_cast<double>(-C) / B;
            // linear equation form when b is NOT 0
            cout << "Solution is " << endl;
            cout << setw(50) << lin_eq << endl;
            cout << setfill('*') << setw(61) << '*' << endl;
            cout << "Thank you for using Quadratic Equation Solver!" << endl;
            cout << setfill('*') << setw(61) << '*' << endl;
        }
    }

    else //basically, when A is NOT zero
    {

        cout << "Enter the input for B. " << endl;
        cin >> B;
        cout << "Enter the input for C. " << endl;
        cin >> C;

        double disc = static_cast<double>((B*B) - (4.0 * A*C));
        double quad_1 = static_cast<double>((-B) + sqrt((B*B) - (4.0 * A*C))) / (2.0 * A);
        double quad_2 = static_cast<double>((-B) - sqrt((B*B) - (4.0 * A*C))) / (2.0 * A);


        if (disc > 0) // discriminant greater than 0
                      // 2 solutions are printed 
        {
            cout << "The two real solutions are" << setw(31) << quad_1 << endl;
            cout << setw(20) << "and" << setw(51) << quad_2;
            cout << setfill('*') << setw(61) << '*' << endl;
            cout << "Thank you for using Quadratic Equation Solver!" << endl;
            cout << setfill('*') << setw(61) << '*' << endl;
        }

        else if (disc == 0)
        {
            cout << "Solution is " << endl;
            cout << setw(50) << quad_2 << endl;
            cout << setfill('*') << setw(61) << '*' << endl;
            cout << "Thank you for using 5Chan Christina Quadratic Equation Solver!" << endl;
            cout << setfill('*') << setw(61) << '*' << endl;



        }
        else if (disc < 0) // This segment of code 
                           // Prints imaginary values through discriminant abs value
        {

            double imag_help = static_cast<double>(abs(disc));
            double imag_solution_1 = (-B / (2.0 * A));
            double imag_solution_2 = (sqrt(imag_help) / (2.0 * A));
            cout << "The two imaginary solutions ARE" << setw(31) << "x= " << imag_solution_1 << " + " << imag_solution_2 << "i" << endl;
            cout << setw(15) << " AND " << setw(31) << "x=" << imag_solution_1 << " - " << imag_solution_2 << "i" << endl;
            cout << setfill('*') << setw(61) << endl;
            cout << "Thank you for using Quadratic Equation Solver." << endl;
            cout << setfill('*') << setw(61) << endl;

        }

    }
}