SlideShare una empresa de Scribd logo
1 de 18
• Algoritmo de Búsqueda.
• Vector.
Algoritmo de búsqueda
Un algoritmo de búsqueda es aquel que está diseñado para localizar un
elemento con ciertas propiedades dentro de una estructura de datos; por
ejemplo, ubicar el registro correspondiente a cierta persona en una base
de datos, o el mejor movimiento en una partida de ajedrez.
La variante más simple del problema es la búsqueda de un número en un
vector.
Búsqueda dicotómica
Elementos necesarios en una búsqueda :
log2(n) donde n = elementos de la búsqueda
Ejemplo: log2(1.000.000) ≈ 20
Búsqueda secuencial.
Se utiliza cuando el vector no está ordenado o no puede ser ordenado
previamente. Consiste en buscar el elemento comparándolo
secuencialmente (de ahí su nombre) con cada elemento del arreglo hasta
encontrarlo, o hasta que se llegue al final. La existencia se puede asegurar
cuando el elemento es localizado, pero no podemos asegurar la no
existencia hasta no haber analizado todos los elementos del arreglo. A
continuación se muestra el pseudocódigo del algoritmo:
Búsqueda dicotómica (binaria).
Se utiliza cuando el vector en el que queremos determinar la existencia de un elemento
está previamente ordenado. Este algoritmo reduce el tiempo de búsqueda
considerablemente, ya que disminuye exponencialmente el número de iteraciones
necesarias.
Está altamente recomendado para buscar en arrays de gran tamaño. Por ejemplo, en uno
conteniendo 50.000.000 elementos, realiza como máximo 26 comparaciones (en el peor
de los casos).
Para implementar este algoritmo se compara el elemento a buscar con un elemento
cualquiera del array (normalmente el elemento central): si el valor de éste es mayor que
el del elemento buscado se repite el procedimiento en la parte del array que va desde el
inicio de éste hasta el elemento tomado, en caso contrario se toma la parte del array que
va desde el elemento tomado hasta el final. De esta manera obtenemos intervalos cada
vez más pequeños, hasta que se obtenga un intervalo indivisible. Si el elemento no se
encuentra dentro de este último entonces se deduce que el elemento buscado no se
encuentra en todo el array.
A continuación se presenta el pseudocódigo del algoritmo, tomando como elemento
inicial el elemento central del array.
Implementación Recursiva en C++
Vector
Informática
En programación, una matriz o vector (llamados en inglés arrays) es una zona de
almacenamiento continuo, que contiene una serie de elementos del mismo tipo, los
elementos de la matriz. Desde el punto de vista lógico una matriz se puede ver como un
conjunto de elementos ordenados en fila (o filas y columnas si tuviera dos
dimensiones).
En principio, se puede considerar que todas las matrices son de una dimensión, la
dimensión principal, pero los elementos de dicha fila pueden ser a su vez matrices (un
proceso que puede ser recursivo), lo que nos permite hablar de la existencia de
matrices multidimensionales, aunque las más fáciles de imaginar son los de una, dos y
tres dimensiones.
Estas estructuras de datos son adecuadas para situaciones en las que el acceso a los
datos se realice de forma aleatoria e impredecible. Por el contrario, si los elementos
pueden estar ordenados y se va a utilizar acceso secuencial sería más adecuado utilizar
una lista, ya que esta estructura puede cambiar de tamaño fácilmente durante la
ejecución de un programa.
Índices.
Todo vector se compone de un determinado número de elementos. Cada
elemento es referenciado por la posición que ocupa dentro del vector. Dichas
posiciones son llamadas índice y siempre son correlativos. Existen tres formas
de indexar los elementos de una matriz:
• Indexación base-cero (0): En este modo el primer elemento del vector será
la componente cero ('0') del mismo, es decir, tendrá el índice '0'. En
consecuencia, si el vector tiene 'n' componentes la última tendrá como
índice el valor 'n-1'. El lenguaje C es un ejemplo típico que utiliza este
modo de indexación.
• Indexación base-uno (1): En esta forma de indexación, el primer elemento
de la matriz tiene el índice '1' y el último tiene el índice 'n' (para una
matriz de 'n' componentes).
• Indexación base-n (n): Este es un modo versátil de indexación en la que el
índice del primer elemento puede ser elegido libremente, en algunos
lenguajes de programación se permite que los índices puedan ser
negativos e incluso de cualquier tipo escalar (también cadenas de
caracteres).
Notación.
La representación de un elemento en un vector se suele hacer mediante el
identificador del vector seguido del índice entre corchetes, paréntesis o llaves:
Aunque muchas veces en pseudocódigo y en libros de matemática se
representan como letras acompañadas de un subíndice numérico que indica
la posición a la que se quiere acceder. Por ejemplo, para un vector "A":
Forma de acceso:
La forma de acceder a los elementos de la matriz es directa; esto significa
que el elemento deseado es obtenido a partir de su índice y no hay que ir
buscándolo elemento por elemento (en contraposición, en el caso de una
lista, para llegar, por ejemplo, al tercer elemento hay que acceder a los dos
anteriores o almacenar un apuntador o puntero que permita acceder de
manera rápida a ese elemento).
Para trabajar con vectores muchas veces es preciso recorrerlos. Esto se
realiza por medio de bucles. El siguiente pseudocódigo muestra un
algoritmo típico para recorrer un vector y aplicar una función a
cada una de las componentes del vector:
Vectores dinámicos y estáticos.
Lo habitual es que un vector tenga una cantidad fija de memoria asignada,
aunque dependiendo del tipo de vector y del lenguaje de programación un
vector podría tener una cantidad variable de datos. En este caso, se les
denomina vectores dinámicos, en oposición, a los vectores con una cantidad
fija de memoria asignada se los denomina vectores estáticos.
El uso de vectores dinámicos requiere realizar una apropiada gestión de
memoria dinámica. Un uso incorrecto de los vectores dinámicos, o mejor
dicho, una mala gestión de la memoria dinámica, puede conducir a una fuga
de memoria. Al utilizar vectores dinámicos siempre habrá que liberar la
memoria utilizada cuando ésta ya no se vaya a seguir utilizando.
Lenguajes más modernos y de más alto nivel, cuentan con un mecanismo
denominado recolector de basura (como es el caso de Java) que permiten
que el programa decida si debe liberar el espacio basándose en si se va a
utilizar en el futuro o no un determinado objeto.
Ejemplo en C
Comienzo del vector
(vector (0), primer
elemento)
((indice * sizeof (int)
cantidad de bytes de
desplazamiento desde la
base.)
El ejemplo anterior está hecho para el lenguaje C++. En C, para crear
vectores dinámicos se tendrían que utilizar las instrucciones malloc y realloc
para reservar memoria de forma dinámica (ver biblioteca stdlib.h), y la
función free para liberar la memoria utilizada.
Vectores multidimensionales.
En Basic, Java y otros lenguajes es posible
declarar matrices multidimensionales,
entendiéndolas como un vector de x
dimensión. En dichos casos en número de
elementos del vector es el producto resultante
de cada dimensión.
Por ejemplo el vector v(4,1) tiene 10
elementos se calcula del siguiente modo: (0-4)
* (0-1). Los elementos de la primera
dimensión del vector contiene 5 elementos
que van del '0' al '4' y la 2º dimensión tiene 2
elementos que van desde '0' a '1'. Los
elementos serían accedidos del siguiente
modo:

Más contenido relacionado

La actualidad más candente

Arreglos o dimensiones en pseint
Arreglos o dimensiones en pseintArreglos o dimensiones en pseint
Arreglos o dimensiones en pseintDon Augusto
 
Estructuras De Datos-Arreglos
Estructuras De Datos-Arreglos Estructuras De Datos-Arreglos
Estructuras De Datos-Arreglos Simeon Bordones
 
Estructura de datos: lista, pilas y colas
Estructura de datos: lista, pilas y colasEstructura de datos: lista, pilas y colas
Estructura de datos: lista, pilas y colasHuascar Génere
 
Base de datos (programacion)
Base de datos (programacion)Base de datos (programacion)
Base de datos (programacion)Jessica Parra
 
Memoria dinamica
Memoria dinamicaMemoria dinamica
Memoria dinamicagusolis93
 
Tipos de datos en MySQL
Tipos de datos en MySQLTipos de datos en MySQL
Tipos de datos en MySQLTotus Muertos
 
21 problemas de algoritmo resueltos
21 problemas de algoritmo resueltos21 problemas de algoritmo resueltos
21 problemas de algoritmo resueltosRoldan El Gato
 
Convertir Diagrama Entidad-Relacion a Modelo Relacional.
Convertir Diagrama Entidad-Relacion a Modelo Relacional.Convertir Diagrama Entidad-Relacion a Modelo Relacional.
Convertir Diagrama Entidad-Relacion a Modelo Relacional.Erivan Martinez Ovando
 
Diccionario de datos
Diccionario de datosDiccionario de datos
Diccionario de datosJorge Garcia
 
Base de datos colegio
Base de datos colegioBase de datos colegio
Base de datos colegioCarlos Buezo
 
Estructura del sistema operativo windows
Estructura del sistema operativo windowsEstructura del sistema operativo windows
Estructura del sistema operativo windowsomfib123
 
Topicos Avanzados de Programacion - Unidad 4 programacion concurrente
Topicos Avanzados de Programacion - Unidad 4 programacion concurrenteTopicos Avanzados de Programacion - Unidad 4 programacion concurrente
Topicos Avanzados de Programacion - Unidad 4 programacion concurrenteJosé Antonio Sandoval Acosta
 
Arreglos en PSeInt
Arreglos en PSeIntArreglos en PSeInt
Arreglos en PSeIntJerry
 
Memoria Estatica
Memoria EstaticaMemoria Estatica
Memoria EstaticaJ M
 

La actualidad más candente (20)

Arreglos o dimensiones en pseint
Arreglos o dimensiones en pseintArreglos o dimensiones en pseint
Arreglos o dimensiones en pseint
 
Estructuras De Datos-Arreglos
Estructuras De Datos-Arreglos Estructuras De Datos-Arreglos
Estructuras De Datos-Arreglos
 
Estructura de datos: lista, pilas y colas
Estructura de datos: lista, pilas y colasEstructura de datos: lista, pilas y colas
Estructura de datos: lista, pilas y colas
 
Base de datos (programacion)
Base de datos (programacion)Base de datos (programacion)
Base de datos (programacion)
 
Memoria dinamica
Memoria dinamicaMemoria dinamica
Memoria dinamica
 
Tipos de datos en MySQL
Tipos de datos en MySQLTipos de datos en MySQL
Tipos de datos en MySQL
 
Memoria dinamica
Memoria dinamicaMemoria dinamica
Memoria dinamica
 
21 problemas de algoritmo resueltos
21 problemas de algoritmo resueltos21 problemas de algoritmo resueltos
21 problemas de algoritmo resueltos
 
Diagrama de casos de usos
Diagrama de casos de usosDiagrama de casos de usos
Diagrama de casos de usos
 
Listas,pilas y colas Estructura de Datos
Listas,pilas y colas Estructura de DatosListas,pilas y colas Estructura de Datos
Listas,pilas y colas Estructura de Datos
 
Convertir Diagrama Entidad-Relacion a Modelo Relacional.
Convertir Diagrama Entidad-Relacion a Modelo Relacional.Convertir Diagrama Entidad-Relacion a Modelo Relacional.
Convertir Diagrama Entidad-Relacion a Modelo Relacional.
 
Estructura de Datos - Unidad 6 Metodos de busqueda
Estructura de Datos - Unidad 6 Metodos de busquedaEstructura de Datos - Unidad 6 Metodos de busqueda
Estructura de Datos - Unidad 6 Metodos de busqueda
 
Diccionario de datos
Diccionario de datosDiccionario de datos
Diccionario de datos
 
Ejemplos en PSeint
Ejemplos en PSeintEjemplos en PSeint
Ejemplos en PSeint
 
Base de datos colegio
Base de datos colegioBase de datos colegio
Base de datos colegio
 
Tipos de listas en estructura de datos
Tipos de listas en estructura de datosTipos de listas en estructura de datos
Tipos de listas en estructura de datos
 
Estructura del sistema operativo windows
Estructura del sistema operativo windowsEstructura del sistema operativo windows
Estructura del sistema operativo windows
 
Topicos Avanzados de Programacion - Unidad 4 programacion concurrente
Topicos Avanzados de Programacion - Unidad 4 programacion concurrenteTopicos Avanzados de Programacion - Unidad 4 programacion concurrente
Topicos Avanzados de Programacion - Unidad 4 programacion concurrente
 
Arreglos en PSeInt
Arreglos en PSeIntArreglos en PSeInt
Arreglos en PSeInt
 
Memoria Estatica
Memoria EstaticaMemoria Estatica
Memoria Estatica
 

Similar a Vectores - Informática

Presentacion de vectores
Presentacion de vectoresPresentacion de vectores
Presentacion de vectoresletty20151998
 
Presentacion de vectores y matrices
Presentacion de vectores y matricesPresentacion de vectores y matrices
Presentacion de vectores y matricesletty20151998
 
Vectores en power point [recuperado]
Vectores en power point [recuperado]Vectores en power point [recuperado]
Vectores en power point [recuperado]herminiajimenez123
 
Vectores, matrices y estructuras
Vectores, matrices y estructurasVectores, matrices y estructuras
Vectores, matrices y estructurasrichmadriz
 
Ordenacion y busqueda
Ordenacion y busquedaOrdenacion y busqueda
Ordenacion y busquedaOsirysRock
 
Angela y vicky I-B
Angela y vicky I-BAngela y vicky I-B
Angela y vicky I-BvictoriaRJ
 
Mapas y Diccionarios - Colecciones Parametrizadas
Mapas y Diccionarios - Colecciones ParametrizadasMapas y Diccionarios - Colecciones Parametrizadas
Mapas y Diccionarios - Colecciones ParametrizadasChristian Collaguazo Malla
 
Ordenacion y busqueda
Ordenacion y busquedaOrdenacion y busqueda
Ordenacion y busquedaIrvingMoran4
 
Revista digital vectores y matrices
Revista digital vectores y matricesRevista digital vectores y matrices
Revista digital vectores y matricesflaquita_dany
 
Estructuras de Datos Elementos y Arreglos.ppt
Estructuras de Datos Elementos y Arreglos.pptEstructuras de Datos Elementos y Arreglos.ppt
Estructuras de Datos Elementos y Arreglos.pptAndersonHernandezara
 
Expo array
Expo arrayExpo array
Expo arrayEd Burke
 
Estructura de datos y algoritmos
Estructura de datos y algoritmosEstructura de datos y algoritmos
Estructura de datos y algoritmosrenatodquintero
 
Clase 10 Estructuras De Datos Y Arreglos
Clase 10 Estructuras De Datos Y ArreglosClase 10 Estructuras De Datos Y Arreglos
Clase 10 Estructuras De Datos Y Arreglossalomonaquino
 
Acceso a datos en aplicaciones web del entorno servidor
Acceso a datos en aplicaciones web del entorno servidorAcceso a datos en aplicaciones web del entorno servidor
Acceso a datos en aplicaciones web del entorno servidorJomicast
 

Similar a Vectores - Informática (20)

Presentacion de vectores
Presentacion de vectoresPresentacion de vectores
Presentacion de vectores
 
Presentacion de vectores y matrices
Presentacion de vectores y matricesPresentacion de vectores y matrices
Presentacion de vectores y matrices
 
Vectores y matrices
Vectores y matricesVectores y matrices
Vectores y matrices
 
Vectores en power point [recuperado]
Vectores en power point [recuperado]Vectores en power point [recuperado]
Vectores en power point [recuperado]
 
Grupo
GrupoGrupo
Grupo
 
Vectores, matrices y estructuras
Vectores, matrices y estructurasVectores, matrices y estructuras
Vectores, matrices y estructuras
 
Ordenacion y busqueda
Ordenacion y busquedaOrdenacion y busqueda
Ordenacion y busqueda
 
Angela y vicky I-B
Angela y vicky I-BAngela y vicky I-B
Angela y vicky I-B
 
Mapas y Diccionarios - Colecciones Parametrizadas
Mapas y Diccionarios - Colecciones ParametrizadasMapas y Diccionarios - Colecciones Parametrizadas
Mapas y Diccionarios - Colecciones Parametrizadas
 
Ordenacion y busqueda
Ordenacion y busquedaOrdenacion y busqueda
Ordenacion y busqueda
 
Revista digital vectores y matrices
Revista digital vectores y matricesRevista digital vectores y matrices
Revista digital vectores y matrices
 
Estructuras de Datos Elementos y Arreglos.ppt
Estructuras de Datos Elementos y Arreglos.pptEstructuras de Datos Elementos y Arreglos.ppt
Estructuras de Datos Elementos y Arreglos.ppt
 
Expo array
Expo arrayExpo array
Expo array
 
Arrays
ArraysArrays
Arrays
 
Vectores en programación
Vectores en programaciónVectores en programación
Vectores en programación
 
Matrices en php
Matrices en phpMatrices en php
Matrices en php
 
Estructura de datos y algoritmos
Estructura de datos y algoritmosEstructura de datos y algoritmos
Estructura de datos y algoritmos
 
Clase 10 Estructuras De Datos Y Arreglos
Clase 10 Estructuras De Datos Y ArreglosClase 10 Estructuras De Datos Y Arreglos
Clase 10 Estructuras De Datos Y Arreglos
 
Arrays
ArraysArrays
Arrays
 
Acceso a datos en aplicaciones web del entorno servidor
Acceso a datos en aplicaciones web del entorno servidorAcceso a datos en aplicaciones web del entorno servidor
Acceso a datos en aplicaciones web del entorno servidor
 

Más de compumet sac

DAFA M2 Lectura 8a: RCD-038-2013-OEFA
DAFA M2 Lectura 8a: RCD-038-2013-OEFADAFA M2 Lectura 8a: RCD-038-2013-OEFA
DAFA M2 Lectura 8a: RCD-038-2013-OEFAcompumet sac
 
DAFA M2 Lectura 8: Política Nacional del Ambiente
DAFA M2 Lectura 8: Política Nacional del AmbienteDAFA M2 Lectura 8: Política Nacional del Ambiente
DAFA M2 Lectura 8: Política Nacional del Ambientecompumet sac
 
DAFA M2 Lectura 07: Reflexiones Sobre OEFA
DAFA M2 Lectura 07: Reflexiones Sobre OEFADAFA M2 Lectura 07: Reflexiones Sobre OEFA
DAFA M2 Lectura 07: Reflexiones Sobre OEFAcompumet sac
 
DAFA Lectura 06: Plana 2011-2021
DAFA Lectura 06: Plana 2011-2021DAFA Lectura 06: Plana 2011-2021
DAFA Lectura 06: Plana 2011-2021compumet sac
 
SIG-G3-M3 Lectura 10: DS-004-2014 PRODUCE
SIG-G3-M3 Lectura 10: DS-004-2014 PRODUCESIG-G3-M3 Lectura 10: DS-004-2014 PRODUCE
SIG-G3-M3 Lectura 10: DS-004-2014 PRODUCEcompumet sac
 
DAFA M1 Lectura 04 : Código de Etica del Auditor Gubernamental del Perú
DAFA M1 Lectura 04 : Código de Etica del Auditor Gubernamental del PerúDAFA M1 Lectura 04 : Código de Etica del Auditor Gubernamental del Perú
DAFA M1 Lectura 04 : Código de Etica del Auditor Gubernamental del Perúcompumet sac
 
DAFA M1 Lectura 03 : Modifican Normas y Manual de Auditoría Gubernamental,
DAFA M1 Lectura 03 : Modifican Normas y Manual de Auditoría Gubernamental,DAFA M1 Lectura 03 : Modifican Normas y Manual de Auditoría Gubernamental,
DAFA M1 Lectura 03 : Modifican Normas y Manual de Auditoría Gubernamental,compumet sac
 
SIG-FB4, Modulo II - Lectura 5b OHSAS 18002
SIG-FB4, Modulo II - Lectura 5b OHSAS 18002SIG-FB4, Modulo II - Lectura 5b OHSAS 18002
SIG-FB4, Modulo II - Lectura 5b OHSAS 18002compumet sac
 
SIG-FB4, Modulo II - Lectura 5a OHSAS 18001
SIG-FB4, Modulo II - Lectura 5a OHSAS 18001SIG-FB4, Modulo II - Lectura 5a OHSAS 18001
SIG-FB4, Modulo II - Lectura 5a OHSAS 18001compumet sac
 
SIG-FB4, Modulo II, Lectura 04 Directrices de la OIT
SIG-FB4, Modulo II, Lectura 04 Directrices de la OITSIG-FB4, Modulo II, Lectura 04 Directrices de la OIT
SIG-FB4, Modulo II, Lectura 04 Directrices de la OITcompumet sac
 
SIG-FB4, Modulo II, Tema 02 Gestión de la Salud en el Trabajo
SIG-FB4, Modulo II, Tema 02 Gestión de la Salud en el TrabajoSIG-FB4, Modulo II, Tema 02 Gestión de la Salud en el Trabajo
SIG-FB4, Modulo II, Tema 02 Gestión de la Salud en el Trabajocompumet sac
 
Diplomatura Sistema de Gestión SIG-FB4 - 13Junio2015
Diplomatura Sistema de Gestión SIG-FB4 - 13Junio2015Diplomatura Sistema de Gestión SIG-FB4 - 13Junio2015
Diplomatura Sistema de Gestión SIG-FB4 - 13Junio2015compumet sac
 
AyC M3 Lectura 09 > Gestion de Inventarios
AyC M3 Lectura 09 > Gestion de InventariosAyC M3 Lectura 09 > Gestion de Inventarios
AyC M3 Lectura 09 > Gestion de Inventarioscompumet sac
 
DS 040-2014-EM > Reglamento de Proteccion Ambiental
DS 040-2014-EM > Reglamento de Proteccion AmbientalDS 040-2014-EM > Reglamento de Proteccion Ambiental
DS 040-2014-EM > Reglamento de Proteccion Ambientalcompumet sac
 
AyC M2 Lectura 08b > RM-004-2014-MINSA Modif_312
AyC M2 Lectura 08b > RM-004-2014-MINSA Modif_312AyC M2 Lectura 08b > RM-004-2014-MINSA Modif_312
AyC M2 Lectura 08b > RM-004-2014-MINSA Modif_312compumet sac
 
AyC M2 Lectura 08a > RM-312-2011-MINSA
AyC M2 Lectura 08a > RM-312-2011-MINSAAyC M2 Lectura 08a > RM-312-2011-MINSA
AyC M2 Lectura 08a > RM-312-2011-MINSAcompumet sac
 
CdP m3Lectura 12 : Fe de Erratas PNDP
CdP m3Lectura 12 :  Fe de Erratas PNDPCdP m3Lectura 12 :  Fe de Erratas PNDP
CdP m3Lectura 12 : Fe de Erratas PNDPcompumet sac
 
CdP m3 Lectura 12 : PNDP
CdP m3 Lectura 12 : PNDPCdP m3 Lectura 12 : PNDP
CdP m3 Lectura 12 : PNDPcompumet sac
 
AyC m2 Lectura 7 : OHSAS 18001
AyC m2 Lectura 7 : OHSAS 18001AyC m2 Lectura 7 : OHSAS 18001
AyC m2 Lectura 7 : OHSAS 18001compumet sac
 

Más de compumet sac (20)

DAFA M2 Lectura 8a: RCD-038-2013-OEFA
DAFA M2 Lectura 8a: RCD-038-2013-OEFADAFA M2 Lectura 8a: RCD-038-2013-OEFA
DAFA M2 Lectura 8a: RCD-038-2013-OEFA
 
DAFA M2 Lectura 8: Política Nacional del Ambiente
DAFA M2 Lectura 8: Política Nacional del AmbienteDAFA M2 Lectura 8: Política Nacional del Ambiente
DAFA M2 Lectura 8: Política Nacional del Ambiente
 
DAFA M2 Lectura 07: Reflexiones Sobre OEFA
DAFA M2 Lectura 07: Reflexiones Sobre OEFADAFA M2 Lectura 07: Reflexiones Sobre OEFA
DAFA M2 Lectura 07: Reflexiones Sobre OEFA
 
DAFA Lectura 06: Plana 2011-2021
DAFA Lectura 06: Plana 2011-2021DAFA Lectura 06: Plana 2011-2021
DAFA Lectura 06: Plana 2011-2021
 
DIRSOCYM
DIRSOCYMDIRSOCYM
DIRSOCYM
 
SIG-G3-M3 Lectura 10: DS-004-2014 PRODUCE
SIG-G3-M3 Lectura 10: DS-004-2014 PRODUCESIG-G3-M3 Lectura 10: DS-004-2014 PRODUCE
SIG-G3-M3 Lectura 10: DS-004-2014 PRODUCE
 
DAFA M1 Lectura 04 : Código de Etica del Auditor Gubernamental del Perú
DAFA M1 Lectura 04 : Código de Etica del Auditor Gubernamental del PerúDAFA M1 Lectura 04 : Código de Etica del Auditor Gubernamental del Perú
DAFA M1 Lectura 04 : Código de Etica del Auditor Gubernamental del Perú
 
DAFA M1 Lectura 03 : Modifican Normas y Manual de Auditoría Gubernamental,
DAFA M1 Lectura 03 : Modifican Normas y Manual de Auditoría Gubernamental,DAFA M1 Lectura 03 : Modifican Normas y Manual de Auditoría Gubernamental,
DAFA M1 Lectura 03 : Modifican Normas y Manual de Auditoría Gubernamental,
 
SIG-FB4, Modulo II - Lectura 5b OHSAS 18002
SIG-FB4, Modulo II - Lectura 5b OHSAS 18002SIG-FB4, Modulo II - Lectura 5b OHSAS 18002
SIG-FB4, Modulo II - Lectura 5b OHSAS 18002
 
SIG-FB4, Modulo II - Lectura 5a OHSAS 18001
SIG-FB4, Modulo II - Lectura 5a OHSAS 18001SIG-FB4, Modulo II - Lectura 5a OHSAS 18001
SIG-FB4, Modulo II - Lectura 5a OHSAS 18001
 
SIG-FB4, Modulo II, Lectura 04 Directrices de la OIT
SIG-FB4, Modulo II, Lectura 04 Directrices de la OITSIG-FB4, Modulo II, Lectura 04 Directrices de la OIT
SIG-FB4, Modulo II, Lectura 04 Directrices de la OIT
 
SIG-FB4, Modulo II, Tema 02 Gestión de la Salud en el Trabajo
SIG-FB4, Modulo II, Tema 02 Gestión de la Salud en el TrabajoSIG-FB4, Modulo II, Tema 02 Gestión de la Salud en el Trabajo
SIG-FB4, Modulo II, Tema 02 Gestión de la Salud en el Trabajo
 
Diplomatura Sistema de Gestión SIG-FB4 - 13Junio2015
Diplomatura Sistema de Gestión SIG-FB4 - 13Junio2015Diplomatura Sistema de Gestión SIG-FB4 - 13Junio2015
Diplomatura Sistema de Gestión SIG-FB4 - 13Junio2015
 
AyC M3 Lectura 09 > Gestion de Inventarios
AyC M3 Lectura 09 > Gestion de InventariosAyC M3 Lectura 09 > Gestion de Inventarios
AyC M3 Lectura 09 > Gestion de Inventarios
 
DS 040-2014-EM > Reglamento de Proteccion Ambiental
DS 040-2014-EM > Reglamento de Proteccion AmbientalDS 040-2014-EM > Reglamento de Proteccion Ambiental
DS 040-2014-EM > Reglamento de Proteccion Ambiental
 
AyC M2 Lectura 08b > RM-004-2014-MINSA Modif_312
AyC M2 Lectura 08b > RM-004-2014-MINSA Modif_312AyC M2 Lectura 08b > RM-004-2014-MINSA Modif_312
AyC M2 Lectura 08b > RM-004-2014-MINSA Modif_312
 
AyC M2 Lectura 08a > RM-312-2011-MINSA
AyC M2 Lectura 08a > RM-312-2011-MINSAAyC M2 Lectura 08a > RM-312-2011-MINSA
AyC M2 Lectura 08a > RM-312-2011-MINSA
 
CdP m3Lectura 12 : Fe de Erratas PNDP
CdP m3Lectura 12 :  Fe de Erratas PNDPCdP m3Lectura 12 :  Fe de Erratas PNDP
CdP m3Lectura 12 : Fe de Erratas PNDP
 
CdP m3 Lectura 12 : PNDP
CdP m3 Lectura 12 : PNDPCdP m3 Lectura 12 : PNDP
CdP m3 Lectura 12 : PNDP
 
AyC m2 Lectura 7 : OHSAS 18001
AyC m2 Lectura 7 : OHSAS 18001AyC m2 Lectura 7 : OHSAS 18001
AyC m2 Lectura 7 : OHSAS 18001
 

Último

04. Sistema de fuerzas equivalentes II - UCV 2024 II.pdf
04. Sistema de fuerzas equivalentes II - UCV 2024 II.pdf04. Sistema de fuerzas equivalentes II - UCV 2024 II.pdf
04. Sistema de fuerzas equivalentes II - UCV 2024 II.pdfCristhianZetaNima
 
01 MATERIALES AERONAUTICOS VARIOS clase 1.ppt
01 MATERIALES AERONAUTICOS VARIOS clase 1.ppt01 MATERIALES AERONAUTICOS VARIOS clase 1.ppt
01 MATERIALES AERONAUTICOS VARIOS clase 1.pptoscarvielma45
 
CLASe número 4 fotogrametria Y PARALAJE.pptx
CLASe número 4 fotogrametria Y PARALAJE.pptxCLASe número 4 fotogrametria Y PARALAJE.pptx
CLASe número 4 fotogrametria Y PARALAJE.pptxbingoscarlet
 
Manual_Identificación_Geoformas_140627.pdf
Manual_Identificación_Geoformas_140627.pdfManual_Identificación_Geoformas_140627.pdf
Manual_Identificación_Geoformas_140627.pdfedsonzav8
 
Sesión 02 TIPOS DE VALORIZACIONES CURSO Cersa
Sesión 02 TIPOS DE VALORIZACIONES CURSO CersaSesión 02 TIPOS DE VALORIZACIONES CURSO Cersa
Sesión 02 TIPOS DE VALORIZACIONES CURSO CersaXimenaFallaLecca1
 
LA APLICACIÓN DE LAS PROPIEDADES TEXTUALES A LOS TEXTOS.pdf
LA APLICACIÓN DE LAS PROPIEDADES TEXTUALES A LOS TEXTOS.pdfLA APLICACIÓN DE LAS PROPIEDADES TEXTUALES A LOS TEXTOS.pdf
LA APLICACIÓN DE LAS PROPIEDADES TEXTUALES A LOS TEXTOS.pdfbcondort
 
CARGAS VIVAS Y CARGAS MUERTASEXPOCI.pptx
CARGAS VIVAS Y CARGAS MUERTASEXPOCI.pptxCARGAS VIVAS Y CARGAS MUERTASEXPOCI.pptx
CARGAS VIVAS Y CARGAS MUERTASEXPOCI.pptxvalenciaespinozadavi1
 
COMPEDIOS ESTADISTICOS DE PERU EN EL 2023
COMPEDIOS ESTADISTICOS DE PERU EN EL 2023COMPEDIOS ESTADISTICOS DE PERU EN EL 2023
COMPEDIOS ESTADISTICOS DE PERU EN EL 2023RonaldoPaucarMontes
 
ECONOMIA APLICADA SEMANA 555555555544.pdf
ECONOMIA APLICADA SEMANA 555555555544.pdfECONOMIA APLICADA SEMANA 555555555544.pdf
ECONOMIA APLICADA SEMANA 555555555544.pdfmatepura
 
Maquinaria Agricola utilizada en la produccion de Piña.pdf
Maquinaria Agricola utilizada en la produccion de Piña.pdfMaquinaria Agricola utilizada en la produccion de Piña.pdf
Maquinaria Agricola utilizada en la produccion de Piña.pdfdanielJAlejosC
 
CAPITULO 4 ANODIZADO DE ALUMINIO ,OBTENCION Y PROCESO
CAPITULO 4 ANODIZADO DE ALUMINIO ,OBTENCION Y PROCESOCAPITULO 4 ANODIZADO DE ALUMINIO ,OBTENCION Y PROCESO
CAPITULO 4 ANODIZADO DE ALUMINIO ,OBTENCION Y PROCESOLUISDAVIDVIZARRETARA
 
PostgreSQL on Kubernetes Using GitOps and ArgoCD
PostgreSQL on Kubernetes Using GitOps and ArgoCDPostgreSQL on Kubernetes Using GitOps and ArgoCD
PostgreSQL on Kubernetes Using GitOps and ArgoCDEdith Puclla
 
Mapas y cartas topográficas y de suelos.pptx
Mapas y cartas topográficas y de suelos.pptxMapas y cartas topográficas y de suelos.pptx
Mapas y cartas topográficas y de suelos.pptxMONICADELROCIOMUNZON1
 
Principales aportes de la carrera de William Edwards Deming
Principales aportes de la carrera de William Edwards DemingPrincipales aportes de la carrera de William Edwards Deming
Principales aportes de la carrera de William Edwards DemingKevinCabrera96
 
hitos del desarrollo psicomotor en niños.docx
hitos del desarrollo psicomotor en niños.docxhitos del desarrollo psicomotor en niños.docx
hitos del desarrollo psicomotor en niños.docxMarcelaArancibiaRojo
 
PERFORACIÓN Y VOLADURA EN MINERÍA APLICADO
PERFORACIÓN Y VOLADURA EN MINERÍA APLICADOPERFORACIÓN Y VOLADURA EN MINERÍA APLICADO
PERFORACIÓN Y VOLADURA EN MINERÍA APLICADOFritz Rebaza Latoche
 
NTP- Determinación de Cloruros en suelos y agregados (1) (1).pptx
NTP- Determinación de Cloruros  en suelos y agregados (1) (1).pptxNTP- Determinación de Cloruros  en suelos y agregados (1) (1).pptx
NTP- Determinación de Cloruros en suelos y agregados (1) (1).pptxBRAYANJOSEPTSANJINEZ
 
Propuesta para la creación de un Centro de Innovación para la Refundación ...
Propuesta para la creación de un Centro de Innovación para la Refundación ...Propuesta para la creación de un Centro de Innovación para la Refundación ...
Propuesta para la creación de un Centro de Innovación para la Refundación ...Dr. Edwin Hernandez
 
Obras paralizadas en el sector construcción
Obras paralizadas en el sector construcciónObras paralizadas en el sector construcción
Obras paralizadas en el sector construcciónXimenaFallaLecca1
 
tema05 estabilidad en barras mecanicas.pdf
tema05 estabilidad en barras mecanicas.pdftema05 estabilidad en barras mecanicas.pdf
tema05 estabilidad en barras mecanicas.pdfvictoralejandroayala2
 

Último (20)

04. Sistema de fuerzas equivalentes II - UCV 2024 II.pdf
04. Sistema de fuerzas equivalentes II - UCV 2024 II.pdf04. Sistema de fuerzas equivalentes II - UCV 2024 II.pdf
04. Sistema de fuerzas equivalentes II - UCV 2024 II.pdf
 
01 MATERIALES AERONAUTICOS VARIOS clase 1.ppt
01 MATERIALES AERONAUTICOS VARIOS clase 1.ppt01 MATERIALES AERONAUTICOS VARIOS clase 1.ppt
01 MATERIALES AERONAUTICOS VARIOS clase 1.ppt
 
CLASe número 4 fotogrametria Y PARALAJE.pptx
CLASe número 4 fotogrametria Y PARALAJE.pptxCLASe número 4 fotogrametria Y PARALAJE.pptx
CLASe número 4 fotogrametria Y PARALAJE.pptx
 
Manual_Identificación_Geoformas_140627.pdf
Manual_Identificación_Geoformas_140627.pdfManual_Identificación_Geoformas_140627.pdf
Manual_Identificación_Geoformas_140627.pdf
 
Sesión 02 TIPOS DE VALORIZACIONES CURSO Cersa
Sesión 02 TIPOS DE VALORIZACIONES CURSO CersaSesión 02 TIPOS DE VALORIZACIONES CURSO Cersa
Sesión 02 TIPOS DE VALORIZACIONES CURSO Cersa
 
LA APLICACIÓN DE LAS PROPIEDADES TEXTUALES A LOS TEXTOS.pdf
LA APLICACIÓN DE LAS PROPIEDADES TEXTUALES A LOS TEXTOS.pdfLA APLICACIÓN DE LAS PROPIEDADES TEXTUALES A LOS TEXTOS.pdf
LA APLICACIÓN DE LAS PROPIEDADES TEXTUALES A LOS TEXTOS.pdf
 
CARGAS VIVAS Y CARGAS MUERTASEXPOCI.pptx
CARGAS VIVAS Y CARGAS MUERTASEXPOCI.pptxCARGAS VIVAS Y CARGAS MUERTASEXPOCI.pptx
CARGAS VIVAS Y CARGAS MUERTASEXPOCI.pptx
 
COMPEDIOS ESTADISTICOS DE PERU EN EL 2023
COMPEDIOS ESTADISTICOS DE PERU EN EL 2023COMPEDIOS ESTADISTICOS DE PERU EN EL 2023
COMPEDIOS ESTADISTICOS DE PERU EN EL 2023
 
ECONOMIA APLICADA SEMANA 555555555544.pdf
ECONOMIA APLICADA SEMANA 555555555544.pdfECONOMIA APLICADA SEMANA 555555555544.pdf
ECONOMIA APLICADA SEMANA 555555555544.pdf
 
Maquinaria Agricola utilizada en la produccion de Piña.pdf
Maquinaria Agricola utilizada en la produccion de Piña.pdfMaquinaria Agricola utilizada en la produccion de Piña.pdf
Maquinaria Agricola utilizada en la produccion de Piña.pdf
 
CAPITULO 4 ANODIZADO DE ALUMINIO ,OBTENCION Y PROCESO
CAPITULO 4 ANODIZADO DE ALUMINIO ,OBTENCION Y PROCESOCAPITULO 4 ANODIZADO DE ALUMINIO ,OBTENCION Y PROCESO
CAPITULO 4 ANODIZADO DE ALUMINIO ,OBTENCION Y PROCESO
 
PostgreSQL on Kubernetes Using GitOps and ArgoCD
PostgreSQL on Kubernetes Using GitOps and ArgoCDPostgreSQL on Kubernetes Using GitOps and ArgoCD
PostgreSQL on Kubernetes Using GitOps and ArgoCD
 
Mapas y cartas topográficas y de suelos.pptx
Mapas y cartas topográficas y de suelos.pptxMapas y cartas topográficas y de suelos.pptx
Mapas y cartas topográficas y de suelos.pptx
 
Principales aportes de la carrera de William Edwards Deming
Principales aportes de la carrera de William Edwards DemingPrincipales aportes de la carrera de William Edwards Deming
Principales aportes de la carrera de William Edwards Deming
 
hitos del desarrollo psicomotor en niños.docx
hitos del desarrollo psicomotor en niños.docxhitos del desarrollo psicomotor en niños.docx
hitos del desarrollo psicomotor en niños.docx
 
PERFORACIÓN Y VOLADURA EN MINERÍA APLICADO
PERFORACIÓN Y VOLADURA EN MINERÍA APLICADOPERFORACIÓN Y VOLADURA EN MINERÍA APLICADO
PERFORACIÓN Y VOLADURA EN MINERÍA APLICADO
 
NTP- Determinación de Cloruros en suelos y agregados (1) (1).pptx
NTP- Determinación de Cloruros  en suelos y agregados (1) (1).pptxNTP- Determinación de Cloruros  en suelos y agregados (1) (1).pptx
NTP- Determinación de Cloruros en suelos y agregados (1) (1).pptx
 
Propuesta para la creación de un Centro de Innovación para la Refundación ...
Propuesta para la creación de un Centro de Innovación para la Refundación ...Propuesta para la creación de un Centro de Innovación para la Refundación ...
Propuesta para la creación de un Centro de Innovación para la Refundación ...
 
Obras paralizadas en el sector construcción
Obras paralizadas en el sector construcciónObras paralizadas en el sector construcción
Obras paralizadas en el sector construcción
 
tema05 estabilidad en barras mecanicas.pdf
tema05 estabilidad en barras mecanicas.pdftema05 estabilidad en barras mecanicas.pdf
tema05 estabilidad en barras mecanicas.pdf
 

Vectores - Informática

  • 1. • Algoritmo de Búsqueda. • Vector.
  • 2. Algoritmo de búsqueda Un algoritmo de búsqueda es aquel que está diseñado para localizar un elemento con ciertas propiedades dentro de una estructura de datos; por ejemplo, ubicar el registro correspondiente a cierta persona en una base de datos, o el mejor movimiento en una partida de ajedrez. La variante más simple del problema es la búsqueda de un número en un vector. Búsqueda dicotómica Elementos necesarios en una búsqueda : log2(n) donde n = elementos de la búsqueda Ejemplo: log2(1.000.000) ≈ 20
  • 3. Búsqueda secuencial. Se utiliza cuando el vector no está ordenado o no puede ser ordenado previamente. Consiste en buscar el elemento comparándolo secuencialmente (de ahí su nombre) con cada elemento del arreglo hasta encontrarlo, o hasta que se llegue al final. La existencia se puede asegurar cuando el elemento es localizado, pero no podemos asegurar la no existencia hasta no haber analizado todos los elementos del arreglo. A continuación se muestra el pseudocódigo del algoritmo:
  • 4.
  • 5. Búsqueda dicotómica (binaria). Se utiliza cuando el vector en el que queremos determinar la existencia de un elemento está previamente ordenado. Este algoritmo reduce el tiempo de búsqueda considerablemente, ya que disminuye exponencialmente el número de iteraciones necesarias. Está altamente recomendado para buscar en arrays de gran tamaño. Por ejemplo, en uno conteniendo 50.000.000 elementos, realiza como máximo 26 comparaciones (en el peor de los casos). Para implementar este algoritmo se compara el elemento a buscar con un elemento cualquiera del array (normalmente el elemento central): si el valor de éste es mayor que el del elemento buscado se repite el procedimiento en la parte del array que va desde el inicio de éste hasta el elemento tomado, en caso contrario se toma la parte del array que va desde el elemento tomado hasta el final. De esta manera obtenemos intervalos cada vez más pequeños, hasta que se obtenga un intervalo indivisible. Si el elemento no se encuentra dentro de este último entonces se deduce que el elemento buscado no se encuentra en todo el array. A continuación se presenta el pseudocódigo del algoritmo, tomando como elemento inicial el elemento central del array.
  • 6.
  • 8.
  • 10. En programación, una matriz o vector (llamados en inglés arrays) es una zona de almacenamiento continuo, que contiene una serie de elementos del mismo tipo, los elementos de la matriz. Desde el punto de vista lógico una matriz se puede ver como un conjunto de elementos ordenados en fila (o filas y columnas si tuviera dos dimensiones). En principio, se puede considerar que todas las matrices son de una dimensión, la dimensión principal, pero los elementos de dicha fila pueden ser a su vez matrices (un proceso que puede ser recursivo), lo que nos permite hablar de la existencia de matrices multidimensionales, aunque las más fáciles de imaginar son los de una, dos y tres dimensiones. Estas estructuras de datos son adecuadas para situaciones en las que el acceso a los datos se realice de forma aleatoria e impredecible. Por el contrario, si los elementos pueden estar ordenados y se va a utilizar acceso secuencial sería más adecuado utilizar una lista, ya que esta estructura puede cambiar de tamaño fácilmente durante la ejecución de un programa.
  • 11. Índices. Todo vector se compone de un determinado número de elementos. Cada elemento es referenciado por la posición que ocupa dentro del vector. Dichas posiciones son llamadas índice y siempre son correlativos. Existen tres formas de indexar los elementos de una matriz: • Indexación base-cero (0): En este modo el primer elemento del vector será la componente cero ('0') del mismo, es decir, tendrá el índice '0'. En consecuencia, si el vector tiene 'n' componentes la última tendrá como índice el valor 'n-1'. El lenguaje C es un ejemplo típico que utiliza este modo de indexación. • Indexación base-uno (1): En esta forma de indexación, el primer elemento de la matriz tiene el índice '1' y el último tiene el índice 'n' (para una matriz de 'n' componentes). • Indexación base-n (n): Este es un modo versátil de indexación en la que el índice del primer elemento puede ser elegido libremente, en algunos lenguajes de programación se permite que los índices puedan ser negativos e incluso de cualquier tipo escalar (también cadenas de caracteres).
  • 12. Notación. La representación de un elemento en un vector se suele hacer mediante el identificador del vector seguido del índice entre corchetes, paréntesis o llaves: Aunque muchas veces en pseudocódigo y en libros de matemática se representan como letras acompañadas de un subíndice numérico que indica la posición a la que se quiere acceder. Por ejemplo, para un vector "A":
  • 13. Forma de acceso: La forma de acceder a los elementos de la matriz es directa; esto significa que el elemento deseado es obtenido a partir de su índice y no hay que ir buscándolo elemento por elemento (en contraposición, en el caso de una lista, para llegar, por ejemplo, al tercer elemento hay que acceder a los dos anteriores o almacenar un apuntador o puntero que permita acceder de manera rápida a ese elemento). Para trabajar con vectores muchas veces es preciso recorrerlos. Esto se realiza por medio de bucles. El siguiente pseudocódigo muestra un algoritmo típico para recorrer un vector y aplicar una función a cada una de las componentes del vector:
  • 14. Vectores dinámicos y estáticos. Lo habitual es que un vector tenga una cantidad fija de memoria asignada, aunque dependiendo del tipo de vector y del lenguaje de programación un vector podría tener una cantidad variable de datos. En este caso, se les denomina vectores dinámicos, en oposición, a los vectores con una cantidad fija de memoria asignada se los denomina vectores estáticos. El uso de vectores dinámicos requiere realizar una apropiada gestión de memoria dinámica. Un uso incorrecto de los vectores dinámicos, o mejor dicho, una mala gestión de la memoria dinámica, puede conducir a una fuga de memoria. Al utilizar vectores dinámicos siempre habrá que liberar la memoria utilizada cuando ésta ya no se vaya a seguir utilizando. Lenguajes más modernos y de más alto nivel, cuentan con un mecanismo denominado recolector de basura (como es el caso de Java) que permiten que el programa decida si debe liberar el espacio basándose en si se va a utilizar en el futuro o no un determinado objeto.
  • 16. Comienzo del vector (vector (0), primer elemento) ((indice * sizeof (int) cantidad de bytes de desplazamiento desde la base.)
  • 17. El ejemplo anterior está hecho para el lenguaje C++. En C, para crear vectores dinámicos se tendrían que utilizar las instrucciones malloc y realloc para reservar memoria de forma dinámica (ver biblioteca stdlib.h), y la función free para liberar la memoria utilizada.
  • 18. Vectores multidimensionales. En Basic, Java y otros lenguajes es posible declarar matrices multidimensionales, entendiéndolas como un vector de x dimensión. En dichos casos en número de elementos del vector es el producto resultante de cada dimensión. Por ejemplo el vector v(4,1) tiene 10 elementos se calcula del siguiente modo: (0-4) * (0-1). Los elementos de la primera dimensión del vector contiene 5 elementos que van del '0' al '4' y la 2º dimensión tiene 2 elementos que van desde '0' a '1'. Los elementos serían accedidos del siguiente modo: