Matrices

Iniciado por Dominic91, 2 Septiembre 2019, 23:02 PM

0 Miembros y 1 Visitante están viendo este tema.

Dominic91

la duda que tengo es como guardar el resultado de la suma de 2 matrices bidimensionales en una matriz unidimensional

programa:
Código (cpp) [Seleccionar]
using namespace std;

int main(){
    char opc;
    do{
    fflush(stdin);
    int s,S;
    int matriz[3][2];
    int matriz2[3][2];
    int matrizResultante[3][2];
    int indiceFila, indiceColumna=0;
    printf("Bienvenido, ¿Desea realizar una suma de matrices?-----SI o NO \n");//Se da la bienvenida y se realiza la pregunta al usuario//
printf("1---SI \n");
printf("2---NO \n");//opciones a elegir para el usuario//
cin>>s;
switch(s){

case 1:
for(indiceFila=0; indiceFila<3; indiceFila++)
    {
        for(indiceColumna=0; indiceColumna<2; indiceColumna++)
        {
            printf("Dame un numero para la matriz 1\n");
            scanf("%i", &matriz[indiceFila][indiceColumna]);
        }
    }
     for(indiceFila=0; indiceFila<3; indiceFila++)
    {
        for(indiceColumna=0; indiceColumna<2; indiceColumna++)
        {
            printf("Dame un numero para la matriz 2\n");
            scanf("%i", &matriz2[indiceFila][indiceColumna]);
        }
    }
    for(indiceFila=0; indiceFila<3; indiceFila++)
    {
        for(indiceColumna=0; indiceColumna<2; indiceColumna++)
        {
            matrizResultante[indiceFila][indiceColumna]=matriz[indiceFila][indiceColumna] + matriz2[indiceFila][indiceColumna];
        }
    }
    for(indiceFila=0; indiceFila<3; indiceFila++)
    {
        for(indiceColumna=0; indiceColumna<2; indiceColumna++)
        {
            printf("El resultado de la matriz es %i\n",matrizResultante[indiceFila][indiceColumna]);
        }
    }
    case 2://en caso de que el usuario acepte la segunda opcion, lo enviara a este caso//
cout<<"Gracias por haber utilizado el programa :) ¿desea realizar otra suma?\n";//pregunta al usuario si desea continuar o salir del prgorama//
cout<<"Digite 's' para repetir el proceso\n ";//indicacion de opcion//
cin>>S;
scanf("%c",&opc);
  }
 
    }
    while(opc=='s'||opc=='S');//mientras se cumpla la variable el programa se repetira//
   return 0;
}


por su atencion gracias

Serapis

Una matriz de varias dimensiones, en realdad puedes verla como una matriz de una sola dimensión.

en la mayoría d elenguajes, las dimensiones de una matriz, viene ordenadas por filas no por columnas, luego es lo mismo que leer el texto de un libro, donde el número de línea vendría a ser la segunda dimensión, y cada palabra en la línea la primera dimensión (la primera a la derecha)...
Así un array como este: array(0-9, 0-3), en memoria estaría posicionado así:
0,1,2,3, 0,1,2,3, 0,1,2,3, 0,1,2,3, 0,1,2,3, 0,1,2,3, 0,1,2,3, 0,1,2,3, 0,1,2,3, 0,1,2,3

Es decir ppuedes transformarlo en un array unidmensional simplemente recalculando las psoiciones con cada dimension, la primera (la de la derecha, siempre es correlativa), la siguiente, aumenta desde 0, hasta la cantidad que tiene precisamente la dimension previa, etc... si hay más dimensiones...

en cuanto a la cantidad de ítems del array unidimensional, será la multiplicación de los elementos de cada dimensón
Luego:



cantidad = arraybid1(cantidaddim1 * cantidaddim2 * ... )
memoria para arraunidim(0 a cantidad -1)

Bucle y 0 a 9
    Bucle x 0 a 3
        arrayunidim(n) = arraybid1(y, x) + arraybid2(y, x)
        n +=1
    siguiente
siguiente


En realidad es algo bastante simplón a lo que cualquiera con algo de lógica puede llegar... o simplemente repasando la documentación del lenguaje respecto d elos arrays.

La escuela del mínimo esfuerzo, hace programadores mediocres. Considera estudiar la documentación para tener una base sólida.