200 likes | 319 Views
Matrices. Es una estructura homogénea, compuesta por varios elementos, todos del mismo tipo y almacenados consecutivamente en memoria A cada elemento se puede acceder directamente por el nombre de la variable matriz seguido de uno o más subíndices encerrados entre paréntesis
E N D
Matrices • Es una estructura homogénea, compuesta por varios elementos, todos del mismo tipo y almacenados consecutivamente en memoria • A cada elemento se puede acceder directamente por el nombre de la variable matriz seguido de uno o más subíndices encerrados entre paréntesis • La representación de las matrices se hace mediante variables suscritas o de subíndices y puede tener una o varias dimensiones (subíndices)
Supongamos que tenemos una matriz unidimensional de enteros llamada M, la cual contiene 10 elementos • Los subíndices son enteros consecutivos y que el primer subíndice vale 0. Un subíndice puede ser cualquier expresión entera positiva • Una matriz de dos dimensiones se representa mediante una variable con dos subíndices (fila, columna); una de tres dimensiones se representa mediante una variable con tres subíndices, etc. • El número máximo de dimensiones está limitado a 60 y el número máximo de elementos depende de la memoria disponible Matriz M M(0) M(1) M(2) M(3) M(4) M(5) M(6) M(7) M(8) M(9)
Matrices numéricas unidimensionales • Para crear y utilizar una matriz hay que realizar tres operaciones: declararla, crearla e iniciarla • Declarar una matriz: Dim nombre() As Tipo Donde tipo indica el tipo de los elementos de la matriz; y nombre es un identificador que nombra a la matriz • Ejemplos: Dim m() As Integer Dim temperatura() As Single
Crear una matriz. Significa reservar la cantidad de memoria necesaria para contener todos sus elementos y asignar al nombre de la matriz una referencia a ese bloque Nombre = New tipo(ind_sup) {} Donde nombre es el nombre de la matriz previamente declarada; tipo es el tipo de los elementos de la matriz; e ind_sup es una expresión entera positiva menor o igual que la precisión de un Long, que especifica el índice superior de la matriz y coincide con el número de elementos de la matriz menos uno • Ejemplos: M = New Integer(9) {} Temperatura = New Single(30) {}
Es bastante común declarar y crear la matriz utilizando una sola sentencia Dim nombre() As tipo = New tipo(ind_sup) {} • Ejemplos: Dim m() As Integer = New Integer(9) {} Dim Temperatura() As Single = New Single(30) {} • También es bastante común declarar y crear una matriz utilizando la forma abreviada Dim nombre(ind_sup) As tipo • Ejemplos: Dim m(9) As Integer Dim Temperatura(30) As Single
Iniciar una matriz. Cuando se crea, sus elementos son automáticamente iniciados, igual que sucede con las variables. Si la matriz es numérica, sus elementos son iniciados a 0 y si no es numérica, a un valor análogo al 0; los caracteres al valor ‘\u000’ un elemento booleano a False • Si deseamos iniciar una matriz Dim m() As Integer = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9} Dim temperatura() As Single = {10.0F, 12.3F} Las declaraciones son la forma abreviada de: Dim m() As Integer = New Integer(9) {0, 1, 2, 3, 4, 5, 6, 7, 8, 9} Dim temperatura() As Single = New Single(1) {10.0F, 12.3F}
Acceder a los elementos de una matriz. Se utiliza el nombre de la matriz, seguido de un subíndice entre paréntesis. Esto es, un elemento de una matriz no es más que una variable subindicada; por lo tanto, se puede utilizar exactamente igual que cualquier otra variable • Ejemplos: Dim m(99) As Integer Dim K, A As Integer … A = m(1) + m(99) K = 50 m(k) += 1 m(k + 1) = m(k) • La primera posición es la 0
Si se intenta acceder a un elemento con un subíndice menor que cero o mayor que el número de elementos de la matriz menos uno, Visual Basic lanzara una excepción de tipo IndexOutOfRangeException • La propiedad Length contiene la longitud de la matriz Dim n As Integer = m.Length
Matrices multidimencionales • Es una matriz de dos o más dimensiones • Definición Dim nombre(,…) As tipo = New tipo(expr-1, expr-2, …) {} Dim nombre(expr-1, expr-2, …) As tipo Donde tipo es un número primitivo entero o real. El número de elementos de una matriz multidimencional es el producto de (expr-1 + 1) x (expr-2 + 1) x … • Ejemplos: Dim m(,) As Integer = New Integer(1, 2) {} Dim m(1, 2) As Integer
A partir de cualquiera de las líneas de código anteriores, se crea una matriz bidimensional m con 2 filas y 3 columnas • Para acceder a los elementos de la matriz se utilizan dos subíndices, el primero indicará la fila y el segundo la columna m(1, 2) = x m(0, 1) = m(1,2) • El método GetLength devuelve el número de elementos de la dimensión especificada. m.GetLength(1) 3 Matriz m col 0 col 1 col 2 fila 0 fila 1
Sentencia For Each • Es similar a la sentencia For, con la diferencia de que ahora un bloque de una sentencia o más sentencias se ejecuta repetidamente por cada elemento de una colección de objetos o de una matriz • Sintaxis: For Each (elemento In colección/matriz) sentencia Next Donde elemento se corresponde en cada ejecución de la sentencia con el siguiente elemento de la colección o de la matriz indicada. Sin embargo, este elemento es de sólo lectura, por lo que no se puede utilizar para modificar los valores de la colección
Ejemplo: Dim m(9) As Integer Dim I As Integer For Each I In m txtSalida.Text &= I.ToString & vbCrLf Next
Modificar el tamaño de una matriz • Se puede modificar el tamaño de una matriz existente, en cualquier instante de la ejecución de un programa • Una forma es asignando una matriz diferente a la misma variable • Otra forma es utilizando la sentencia ReDim • En cualquier caso el número de dimensiones no se puede modificar, pero si se puede modificar la longitud de cualquiera de las dimensiones
Ejemplo: Dim m(3, 4) As Integer ‘matriz 4 filas por 5 columnas … m = New Integer(1, 2) {} ‘matriz 2 filas por 3 columnas • Los elementos se pierden • Para conservarlos es necesario utilizar la sentencia ReDim con la cláusula Preserve. En este caso sólo permite modificar la longitud de la última dimensión • Ejemplo: Dim m(2, 3) As Integer … ReDim Preserve m(2, 7)
Números aleatorios • La biblioteca de clases .Net incluye una clase llamada Random, la cual define un conjunto de operaciones relacionadas con la obtención de números al azar
Ejemplo: El código siguiente muestra como obtener un número al azar entre 1 y 49: Dim n As Integer Dim rnd As Random = New Random() n = rnd.Next(1, 50)
Clase Array • La clase Array del espacio de nombres System contiene varios métodos para manipular matrices. • Clone. Permite duplicar una matriz Dim m1() As Integer = {10, 20, 30, 40, 50} Dim m2() As Integer = m1.Clone() • Clear. Asigna un valor 0 o Nothing a todos los elementos de una matriz, o bien a cada elemento de un rango especificado Clear(m As Array, desdeInd As Integer, longitud As Integer) Donde m es la matriz, desdeInd es el índice del primer elemento del rango y longitud el número de elementos del mismo
Ejemplo: Dim a() As Double = {55, 50, 45, 40, 35, 30, 25, 20, 10} System.Array.Clear(a, 0, a.Length) • Sort. Ordena los elementos de una matriz unidimensional en orden ascendente utilizando el algoritmo quicksort Sort(m As Array) Sort(m As Array, desdeInd As Integer, longitud As Integer) Donde m es la matriz a ordenar. Cuando solo queramos ordenar un rango de elementos, utilizaremos el segundo formato de Sort donde desdeInd es el índice del primer elemento del rango y longitud el número de elementos del mismo • Ejemplo: Dim a() As Double = {55, 50, 45, 40, 35, 30, 25, 20, 10} System.Array.Sort(a)
BinarySearch. Busca un valor en una matriz unidimensional que esté ordenada ascendentemente utilizando el algoritmo de búsqueda binaria. BinarySearch(m As Array, clave As Object) As Integer Donde m representa la matriz, clave es el valor que se desea buscar • El valor devuelto es un entero correspondiente al índice del elemento que coincide con el valor buscado. Si el valor buscado no se encuentra, entonces el valor devuelto es: -(punto de inserción) – 1. El valor de punto de inserción es el índice del elemento de la matriz donde debería encontrarse el valor buscado.
Ejemplo: Dim a() As Integer = {10, 15, 20, 25, 30, 35, 40, 45, 50, 55} Dim i As Integer i = System.Array.BinarySearch(a, 25) ‘ i = 3 i = System.Array.BinarySearch(a, 27) ‘ i = -5 i = System.Array.BinarySearch(a, 5) ‘ i = -1 i = System.Array.BinarySearch(a, 60) ‘ i = -11 • Reverse. Invierte la secuencia de todos los elementos de una matriz unidimensional, o bien de los elementos de un rango especificado. Reverse(m As Array) Reverse(m As Array, desdeInd As Integer, longitud As Integer) Donde m es la matriz. Cuando sólo queremos invertir la secuencia de un rango de elementos, utilizaremos el segundo formato de Reverse donde desdeInd es el índice del primer elemento del rango y longitud el numero de elementos del mismo • Ejemplo: Dim a() As Integer = {10, 15, 20, 25, 30, 35, 40, 45, 50, 55} System.Array.Reverse(a)