Mapeo Lexico Grafico Multidimensional
Para obtener la posicion en memoria de cualquiera de sus elementos tenemos la siguiente formula :
![A[ i_{1} ,i_{2}] = A[ i_{1} ,i_{2}] =](https://lh3.googleusercontent.com/blogger_img_proxy/AEn0k_smSvAlvcvEcHBdf_vtVxNOdUZvzgPyi-txF15IZaIfaAN1aX8trKlDiPpd0mwd0fhdgRpTa9PgRZesPP8DmnVrCeXhSZJWwaQULE6lh4PiOp26fGAkB5wngfn9CwJuqtq4igHOMA7UFZvz-qUYLuYRuIjy0UJ1GQ=s0-d)
![base(A) + [ ( (i_{1}-L_{i1})R_1 + (i_{2}-L_{i2}) )*W] base(A) + [ ( (i_{1}-L_{i1})R_1 + (i_{2}-L_{i2}) )*W]](https://lh3.googleusercontent.com/blogger_img_proxy/AEn0k_tOEFf4PBAoTo8c3op6qTcktPDxq_1T4-oSGch2OyJyDTtmX4-TVUuuL0IgqWDrhx9Jl0M5hFHFGbOKBKoDusDcUxhsGlf-kp7LngPEMYbrscC3nKccXdwAZFKMxTc8n_bfaNKfVtdDa3xo5aK5PMQVUObIWaScjmk=s0-d)
donde :
Base del Areglo
Indice del Arreglo 1
Indice del Arreglo 2
Limite inferior Arreglo 1
Limite inferior Arreglo 2
Tamano en bytes de los elementos
(limite superior 1 - limite inferior 1 ) +1
Para un arreglo multidimensional, es decir con
dimensiones tenemos:
![A[ i_{1} ,i_{2},...i_n ] = base(A) + [ ( (i_{3}-L_{i3})R_3*R_2*R_1 A[ i_{1} ,i_{2},...i_n ] = base(A) + [ ( (i_{3}-L_{i3})R_3*R_2*R_1](https://lh3.googleusercontent.com/blogger_img_proxy/AEn0k_t3pB3sR8rOmoX4IBUyiPhgj9HSLTiM1nb1HV_K_mR-d5HyokxYkSIj100LbslwHaKwZTjYVr7ATvzvO91rR-ZNHiAomf3XApwSmbzpi25-N9xhB-fW7-zOPbO2RoAW48QUAmFxki-QLDxUGSjoZP3jSE3Ydy5b0A=s0-d)

![+...+(i_{n}-L_{n}))*W] +...+(i_{n}-L_{n}))*W]](https://lh3.googleusercontent.com/blogger_img_proxy/AEn0k_s8XVpWj2u87AiLNGWBdRu7UwMU8DLbxRSUXD-kc7pcWoiusSbTEgZP0nEx4Nsh-oFRfWdMtHFyONbNp4A5sB1itVDY6ShKLaJdzkXKCGOPFO8Np74udcG23bnzn-8AP_mVN3ASfKVwf2q7lEu7RDtfH3KXT4WKgwg=s0-d)
Ahora veamos el codigo:
Para correrlo (Linux), simplemente crea un archivo llamado MapeoLexicoGrafico.cpp y copia el codigo anterior.
Compilamos el Archivo con el siguiente comando:
g++ MapeoLexicoGrafico.cpp -o Mapeo.out
Corremos el archivo .out con el comando :
./Mapeo.out
La Ejecucion se vera asi:
Ingresa la dimension del vector en un intervalo de 1...n
5
Ingresa la base
100
Ingresa el tamano de bytes
1
Ingresa los datos del vector
2
3
2
4
2
Se procesara el siguiente vector : [ 2, 3, 2, 4, 2, ]
Ingresa la imite inferior para el vector 1
1
Ingresa la imite superior para el vector 1
5
Ingresa la imite inferior para el vector 2
1
Ingresa la imite superior para el vector 2
5
Ingresa la imite inferior para el vector 3
1
Ingresa la imite superior para el vector 3
5
Ingresa la imite inferior para el vector 4
1
Ingresa la imite superior para el vector 4
5
Ingresa la imite inferior para el vector 5
1
Ingresa la imite superior para el vector 5
5
El Resultado es: 1016
Anallicemos la siguiente matriz:
Podemos representarla como :
int A[2][3] = { {1, 2, 3}, {4, 5, 6} };
Una matriz de 2 filas y 3 columnas, es decir 2 dimensiones.Para obtener la posicion en memoria de cualquiera de sus elementos tenemos la siguiente formula :
donde :
Para un arreglo multidimensional, es decir con
Ahora veamos el codigo:
Para correrlo (Linux), simplemente crea un archivo llamado MapeoLexicoGrafico.cpp y copia el codigo anterior.
Compilamos el Archivo con el siguiente comando:
g++ MapeoLexicoGrafico.cpp -o Mapeo.out
Corremos el archivo .out con el comando :
./Mapeo.out
La Ejecucion se vera asi:
Ingresa la dimension del vector en un intervalo de 1...n
5
Ingresa la base
100
Ingresa el tamano de bytes
1
Ingresa los datos del vector
2
3
2
4
2
Se procesara el siguiente vector : [ 2, 3, 2, 4, 2, ]
Ingresa la imite inferior para el vector 1
1
Ingresa la imite superior para el vector 1
5
Ingresa la imite inferior para el vector 2
1
Ingresa la imite superior para el vector 2
5
Ingresa la imite inferior para el vector 3
1
Ingresa la imite superior para el vector 3
5
Ingresa la imite inferior para el vector 4
1
Ingresa la imite superior para el vector 4
5
Ingresa la imite inferior para el vector 5
1
Ingresa la imite superior para el vector 5
5
El Resultado es: 1016







