2013-10-27 24 views
7

risolvere il sistema di due equazioni con due incognite indicatiRisolvere sistema di due equazioni con due incognite

enter image description here

a1, b1, c1, a2, b2 e c2 sono immessi dall'utente stesso.

Ho cercato di trovare una soluzione per la matematica per il problema primo e io non riesco a andare lontano ..

Quello che ho provato finora è:

  1. Dalla prima equazione per trovare y. (b1y = c1-a1x, y = (c1-a1x)/b1)
  2. Quindi sostituisco y nella seconda equazione e ottengo un'equazione con 1 sconosciuto in questo caso x. Tuttavia, non riesco a risolvere l'equazione, ottengo alcuni numeri dispari/equazioni e mi fermo qui.

È corretto o esiste un modo più semplice per eseguire questa operazione?

codice attuale:

#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

codice 'C++' per favore – P0W

+2

nel vostro codice, in primo luogo, dovresti controllare se il tuo sistema di 2 incognite ha una soluzione, infinita o nessuna (calcolare il determinante) – lolando

+2

La soluzione è data direttamente come l'inversa della matrice 2x2 (a1, b1; a2, b2) se la matrice è invertibile (cioè det! = 0). –

risposta

10

si risolve il sistema lineare con 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 equazioni sistema: risultato, x = 1,000000, y = 2,000000