C/Visual C - matriz inversa

 
Vista:

matriz inversa

Publicado por santiago (5 intervenciones) el 16/05/2001 07:07:01
hola , por favor necesito el programa de la matriz inversa en c++, yo habia pedido que em ayudarn con la matriz identidad , gracias al quie lo hizo, pero me equivoque, la que necesito es la inversa.

gracias
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder
Imágen de perfil de Alejandro

Programa para calcular la matriz inversa en C++

Publicado por Alejandro (913 intervenciones) el 25/09/2024 16:48:13
¡Hola, Santiago! Aquí tienes un ejemplo de programa en C++ para calcular la matriz inversa:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include <iostream>
#include <cmath>
 
// Función para imprimir una matriz
void imprimirMatriz(float matriz[][3], int filas, int columnas) {
    for (int i = 0; i < filas; i++) {
        for (int j = 0; j < columnas; j++) {
            std::cout << matriz[i][j] << " ";
        }
        std::cout << std::endl;
    }
}
 
// Función para calcular la matriz inversa
void matrizInversa(float matriz[][3], int n) {
    // Crear una matriz identidad del mismo tamaño que la matriz original
    float matrizIdentidad[3][3] = {{1, 0, 0}, {0, 1, 0}, {0, 0, 1}};
 
    // Realizar operaciones de eliminación gaussiana para convertir la matriz original en la matriz identidad
    for (int i = 0; i < n; i++) {
        float pivote = matriz[i][i];
 
        // Dividir la fila por el pivote para hacer el elemento diagonal igual a 1
        for (int j = 0; j < n; j++) {
            matriz[i][j] /= pivote;
            matrizIdentidad[i][j] /= pivote;
        }
 
        // Restar múltiplos de la fila actual a las demás filas para hacer los elementos debajo y encima del pivote igual a 0
        for (int k = 0; k < n; k++) {
            if (k != i) {
                float factor = matriz[k][i];
 
                for (int j = 0; j < n; j++) {
                    matriz[k][j] -= factor * matriz[i][j];
                    matrizIdentidad[k][j] -= factor * matrizIdentidad[i][j];
                }
            }
        }
    }
 
    // Imprimir la matriz inversa
    std::cout << "Matriz inversa:" << std::endl;
    imprimirMatriz(matrizIdentidad, n, n);
}
 
int main() {
    // Definir la matriz original
    float matriz[3][3] = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
 
    // Calcular la matriz inversa
    matrizInversa(matriz, 3);
 
    return 0;
}

Este programa calcula la matriz inversa de una matriz de 3x3. Puedes modificar la matriz original en el código según tus necesidades. La función `imprimirMatriz` se utiliza para imprimir una matriz en la consola.

Espero que esto te sea útil. ¡Buena suerte con tu programa!
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar