2013-10-27 13 views
7

rozwiązania układu dwóch równań z dwiema niewiadomymi poniżej:układ dwóch równań z dwiema niewiadomymi Rozwiąż

enter image description here

A1, B1, C1, a2, b2 i c2 są wprowadzane przez samego użytkownika.

Próbowałem znaleźć rozwiązanie problemu matematyki dla pierwszej i nie wydaje się daleko ..

Co próbowałem tak daleko jest:

  1. z pierwszego równanie, aby znaleźć y. (b1y = c1-a1x, y = (c1-a1x)/b1)
  2. Potem zastępuję y w drugim równaniu i otrzymuję jedno równanie z 1 nieznanym w tym przypadku x. Jednak nie mogę rozwiązać równania, otrzymuję nieparzyste liczby/równania i zatrzymałem się tutaj.

Czy to prawda, czy jest łatwiejszy sposób na zrobienie tego?

Obecny Kod:

#include <iostream> 

using namespace std; 

int main() 
{ 
    int a1, b1, c1, a2, b2, c2; 
    cout << "Enter the values for the first equation." << endl; 
    cout << "Enter the value for a1" << endl; 
    cin >> a1; 
    cout << "Enter the value for b1" << endl; 
    cin >> b1; 
    cout << "Enter the value for c1" << endl; 
    cin >> c1; 
    cout << "Enter the values for the second equation." << endl; 
    cout << "Enter the value for a2" << endl; 
    cin >> a2; 
    cout << "Enter the value for b2" << endl; 
    cin >> b2; 
    cout << "Enter the value for c2" << endl; 
    cin >> c2; 
    cout << "Your system of equations is the following:" << endl; 
    cout << a1 << "x+" << b1 << "y=" << c1 << endl; 
    cout << a2 << "x+" << b2 << "y=" << c2 << endl; 

if ((a1 * b2) - (b1 * a2) == 0){ 
    cout << "The system has no solution." << endl; 
} 
else{ 
    res_x = ((c1*b2) - (b1*c2))/((a1*b2)-(b1*a2)); 
    res_y = ((a1*c2) - (c1*a2))/((a1*b2) - (b1*a2)); 
    cout << "x=" << res_x << " y=" << res_y << endl; 
} 

    return 0; 
} 
+2

Kod 'C++' proszę – P0W

+2

w swoim kod, po pierwsze, powinieneś sprawdzić, czy twój system 2 niewiadomych ma jedno, nieskończoność lub nie ma rozwiązania (oblicz wyznacznik) – lolando

+2

Rozwiązanie jest bezpośrednio podane jako odwrotność macierzy 2x2 (a1, b1; a2, b2) iff macierz jest odwracalna (to znaczy det! = 0). –

Odpowiedz

10

rozwiązać układ liniowy przy użyciu Cramer's rule:

int main(int argc, char** argv) { 
    /* we solve the linear system 
    * ax+by=e 
    * cx+dy=f 
    */ 
    if(argc != 7) { 
     cerr<<"Cramer equations system: error," 
          " we need a,b,c,d,e,f parameters.\n"; 
     return -1; 
    } 

    double a,b,e; 
    double c,d,f; 
    sscanf(argv[1],"%lf",&a); 
    sscanf(argv[2],"%lf",&b); 
    sscanf(argv[3],"%lf",&e); 
    sscanf(argv[4],"%lf",&c); 
    sscanf(argv[5],"%lf",&d); 
    sscanf(argv[6],"%lf",&f); 

    double determinant = a*d - b*c; 
    if(determinant != 0) { 
     double x = (e*d - b*f)/determinant; 
     double y = (a*f - e*c)/determinant; 
     printf("Cramer equations system: result, x = %f, y = %f\n", x, y); 
    } else { 
     printf("Cramer equations system: determinant is zero\n" 
       "there are either no solutions or many solutions exist.\n"); 
    } 
    return 0; 
} 

./cramer_equation_system 1 2 5 1 -1 -1

Cramer układ równań: rezultatu x = 1.000000, y = 2.000000

Powiązane problemy