matrices
Download
Skip this Video
Download Presentation
Matrices

Loading in 2 Seconds...

play fullscreen
1 / 20

Matrices - PowerPoint PPT Presentation


  • 107 Views
  • Uploaded on

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

loader
I am the owner, or an agent authorized to act on behalf of the owner, of the copyrighted work described.
capcha
Download Presentation

PowerPoint Slideshow about ' Matrices' - aileen-ramirez


An Image/Link below is provided (as is) to download presentation

Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author.While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server.


- - - - - - - - - - - - - - - - - - - - - - - - - - E N D - - - - - - - - - - - - - - - - - - - - - - - - - -
Presentation Transcript
matrices
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)
slide2
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
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

slide4
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) {}

slide5
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

slide6
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}

slide7
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
slide8
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
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

slide10

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
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

slide12

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
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
slide14

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
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
slide16

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
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

slide18

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)

slide19

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.
slide20

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)

ad