INFORMTICA
Tema 3
Estructuras de datos
Estructuras de datos
Estructuras de datos
Dos estructuras de datos fundamentales son las conocidas
como: matriz (o array) y registro (o estructura).
Son de uso frecuente, por lo que son elementos
imprescindibles en la programacin de muchos problemas.
Por ejemplo, las notas correspondientes a las distintas
evaluaciones realizadas a cada uno de los alumnos de un
determinado curso forman una matriz, y la ficha que contiene
los datos personales de cada uno de estos alumnos es un
ejemplo de registro (o estructura).
Estructuras de datos
Matrices
Una matriz (array en ingls) es un conjunto de elementos
contiguos, todos del mismo tipo, que comparten un nombre
comn y a los que es posible acceder mediante la posicin
(ndice) que ocupa cada uno de ellos en la matriz, como un
vector o una matriz en lgebra.
Esta disposicin permitir escribir cdigo ms simple, ya que
ser posible establecer bucles en los que se recorra los
elementos de una matriz mediante el nmero de ndice.
A las matrices de una dimensin se les suele llamar tambin
vectores o listas, y a las matrices de dos dimensiones, tablas.
elemento
Matriz
Matrizaa
...
Estructuras de datos
Matrices
Es posible definir matrices de hasta 60 dimensiones en Visual
Basic y de cualquier tipo de datos (tipos fundamentales y
estructuras definidas por el usuario).
La representacin de las matrices se hace mediante variables
con subndices. Los subndices son nmeros enteros
consecutivos y, por defecto, el primer ndice valdr 0. Una
matriz de dos dimensiones se representa con una variable con
dos subndices (filas, columnas). Una de tres con tres, etctera.
Para formar el nombre de una matriz y definir su tipo, se siguen
las mismas reglas que para las variables:
Dim a(24) As Integer matriz de enteros, 1 dimensiones.
Dim c(12,5) As String matriz de cadenas, 2 dimensiones.
Fundamentos de Informtica. Departamento de Ingeniera de Sistemas y Automtica.
Estructuras de datos
Declaracin de matrices
La declaracin de una matriz especifica el nombre de la matriz, el
nmero de elementos de la misma y el tipo de stos:
Dim variable[(dimension)][As tipo]
donde:
variable es el nombre de la matriz.
dimension es una lista de expresiones numricas, separadas
Estructuras de datos
Estructuras de datos
matriz de n elementos
Estructuras de datos
Matrices dinmicas
Una matriz dinmica, a diferencia de las anteriores, puede ser
redimensionada en cualquier momento de la ejecucin del programa.
Para crear una matriz dinmica, primero hay que declararla como si
fuera una matriz esttica (con Dim), pero sin darle dimensin.
Para reasignar dinmicamente el nmero de elementos se utiliza la
sentencia ReDim. No es posible cambiar el nmero de dimensiones
de la misma, slo los tamaos de cada dimensin.
Cada vez que se ejecuta ReDim, todos los valores previamente
almacenados se pierden.
Para cambiar el tamao conservando los valores hay que utilizar la
palabra clave Preserve, en cuyo caso no es posible cambiar el/los
ndice/s inferior/es, slo el superior.
Fundamentos de Informtica. Departamento de Ingeniera de Sistemas y Automtica.
Estructuras de datos
Estructuras de datos
Para copiar una matriz en otra es necesario asignar uno a uno los
valores de la primera en las variables de la segunda.
La funcin Ubound(variable, dimension) devuelve el valor ms
alto de la dimensin de la variable de tipo matriz indicada.
Fundamentos de Informtica. Departamento de Ingeniera de Sistemas y Automtica.
10
Estructuras de datos
Estructuras: Type
Una estructura o registro es un nuevo tipo de datos, especificado
por el usuario, que puede definirse como una coleccin de datos de
diferentes tipos.
Para declarar una estructura, hay que utilizar la instruccin de
Visual Basic Type ... End Type. Esta instruccin slo puede
aparecer en la seccin Declaraciones de los mdulos.
Type Ficha
Nombre As String * 60
Direccion As String * 40
Telefono As String *12
Edad As Integer
End Type
11
Estructuras de datos
Estructuras: Type
Una vez declarado el tipo de datos, ya es posible declarar variables
de este tipo. Por ejemplo, la siguiente sentencia declara la variable
Alumno de tipo Ficha:
Dim Alumno As Ficha
12
Estructuras de datos
13
Estructuras de datos
14
Estructuras de datos
15
Estructuras de datos
16
FUNDAMENTOS DE
INFORMTICA
Tema 3
Estructuras de datos
17