ESTRUCTURAS DE DATOS ÍNDICE

Slides:



Advertisements
Presentaciones similares
Arreglos Unidimensionales y Bidimensionales ESTRUCTURAS DE DATOS I
Advertisements

Estructuras de Datos (ARRAYS)
ALGORÍTMICA Dpto. Ingeniería de Sistemas y Automática
Aplicación de estructuras de datos
Fundamentos de Programación
TIPOS DE DATOS NO PRIMITIVOS Los arreglos (arrays) son estructuras de datos homogéneos en el sentido de que todos los elementos que lo componen son del.
Lenguaje de programación: Lua Fundamentos de lenguaje de programación. Iván Cardemil Patricio Tudela Camilo Rojas Llosect Moscoso.
Programación II Sesión 3. TABLA DE CONTENIDO  Tipos de Datos en C  Delimitadores  Tipo Char  Tipo Int  Tipo Float  Tipo Double  Constantes  Operadores.
ALGORITMOS Y TIPOS DE DATOS Un algoritmo es un método para resolver un problema. Para la creación de un programa (resolver un problema) en un lenguaje.
Traducción dirigida por la Sintaxis Teoría de Autómatas y Lenguajes Formales Alma María Pisabarro, 2007.
PROGRAMACIÓN ORIENTADA A OBJETOS SEGUNDA UNIDAD: “CLASES, OBJETOS Y MÉTODOS” IRVING YAIR SALAS CHÁVEZ ING. EN SISTEMAS COMPUTACIONALES - ITSLP.
Capítulo 5 Tecnologías para la explotación de la información
BASE DE DATOS.
Ingreso , proceso y salida de datos
¿Cómo almacenar datos dentro del computador?
Excel: Fórmulas y funciones
ALGEBRA DE MATRICES Uso de MatLab.
U.T. 11: Introducción A Las Bases De Datos
MANEJO DE ARRELOGS EN C Clase 8: Arreglos.
TAD’s ARBOLES GENERALIZADOS
LISTAS..
Unidad 7: Nivel Interno Algunos Conceptos Importantes
Tema 6. Conceptos básicos de programación (Clase 2)
TUTORIAL PSeint.
Array Bidemensionales. ¿Qué es una matriz o tabla?  Una matriz es un vector de vectores o también llamado array bidimensional.  Dimensión de un Arreglo:
TIPO DE DATOS EN ACCESS 2010 TEXTO, MEMO, NUMERO, FECHA/HORA, MONEDA, AUTONUMERACION, SI/NO, OBJETO OLE, HIPERVINCULO, DATOS ADJUNTADOS, CALCULADO Y ASISTENTES.
Constantes y variables
Listas Dinámicas.
Tipos de Datos abstractos
Vectores Unidad II A Z L D Comenzar.
LÓGICA DE PROGRAMACIÓN
EXPRESIONES Una expresión es una forma especial de asignación.
ALGORITMOS es un conjunto preescrito de instrucciones o reglas bien definidas, ordenadas y finitas que permite realizar una actividad mediante pasos.
Unidad 3. Introducción a la programación
Introducción a las estructuras de datos
Tipos Básicos.
Algoritmo Capitulo Cinco.
Hipervínculos scratch
Conceptos Relacionados Unidad I. Parte A.
Excel.
ARREGLOS BIDIMENSIONALES MATRICES Son un espacio de almacenamiento continuo, que contiene una serie de elementos del mismo tipo de datos. Desde el punto.
ELEMENTOS DE COMPUTACIÓN Profesor: Guillermo Figueroa
HERRAMIENTAS DE PROGRAMACIÓN
U NIVERSIDAD S AN P EDRO F ILIAL B ARRANCA F ACULTAD DE I NGENIERÍA E SCUELA P ROFESIONAL DE I NG. I NFORMÁTICA Y DE S ISTEMAS C URSO : ALGORITMOS Tema.
Introducción al Visual Basic  Un programa en sentido informático está constituido en un sentido general por variables que contienen los datos con los.
Programación lógica y funcional Unidad I Conceptos fundamentales.
INFORMÁTICA II BLOQUE I: ALGORITMOS Y DIAGRAMAS DE FLUJO
CURSO PROGRAMACIÓN BÁSICA SEMANA 3 ¿Qué es un programa?
ABSTRACCION DE DATOS   Estructura de Datos Básicos: En programación una estructurad de datos, es una forma particular de organizar datos en una computadora.
Unidad 1 Definiciones Básicas
Procesamiento de señales Introducción a Matlab 2014
Instituto Tecnológico de Minatitlán
LICENCIATURA EN SISTEMAS COMPUTACIONALES EN ADMINISTRACION
TEMAS *Arboles Binarios *listas Abiertas y Cerradas - Inserción - Recorrido - Eliminación *Pilas - Concepto - Inserción - Recorrido -
Listas ligadas Dra. María de Lourdes López García
FUNDAMENTOS DE PROGRAMACIÓN. INTRODUCCIÓN  Conceptos: Informática, Ordenador, Programa, Dato, Bit, Byte, Hardware, Software, Lenguaje de Programación,
M. en TI. Omar Téllez Barrientos DOCENTE DE INFORMÁTICA GENERACIÓN DE PSEUDOCÓDIGOS Y ALGORITMOS
DEPARTAMENTO DE MATEMÁTICAS
MATRICES. ¿QUÉ ES UNA MATRIZ? Una matriz es un espacio bidimensional que se genera en la memoria del computador. Las matrices deben tener un nombre que.
TUTORIAL PS EINT FUNDAMENTOS DE PROGRAMACIÓN Ing. Elizabeth Díaz Orea.
TUTORIAL PS EINT FUNDAMENTOS DE PROGRAMACIÓN Ing. Elizabeth Díaz Orea.
Tema 6. Conceptos básicos de programación (Clase 2)
NATURALEZA DE LOS DATOS Valores Numéricos Son los valores que se pueden hacer cálculos aritméticosritméticos Tipos de valores Entero Real Cadena ( “ h”
Lenguaje de Programación II
CONTROLES Y ESTRUCTURAS BÁSICAS DE PROGRAMACIÓN  1. Algoritmos: conjunto de instrucciones programadas para resolver una tarea específica.  2. Datos:
EUPs que imprima la tabla de multiplicar de 2 al 10
Access Este programa permite manipular datos en forma de tablas, realizar cálculos complejos con fórmulas y funciones, incluso dibujar distintos tipos.
UNIDAD II Generalidades sobre Algoritmos
Profesor del curso: UNIVERSIDAD NACIONAL DEL CENTRO DEL PERU 2019-I Facultad de Ingeniería de Sistemas 1.
UNIDAD VI (continuación) ARREGLO BIDIMENSIONAL
Transcripción de la presentación:

ESTRUCTURAS DE DATOS ÍNDICE IC-t2 Información estructurada y no estructurada Tipos básicos Tipos de datos estructurados Estructuras estáticas y dinámicas de 27

IC-t2 ESTRUCTURAS DE DATOS Información estructurada y no estructurada Estamos acostumbrados a manejar información estructurada, por ejemplo, nuestro lenguaje. Se compone de letras que se combinan formando sílabas y éstas formando palabras y éstas oraciones simples o compuestas. De ahí se puede pasar a párrafos, capítulos y llegar a libros de ensayo o a volúmenes de una enciclopedia. Sin embargo, esas letras pueden dar lugar a combinaciones no estructuradas dentro de las reglas de nuestro lenguaje. Pero también esas palabras podrían ordenarse en castellano de una manera estructurada, incluso aunque semánticamente no tuvieran sentido. Oración desestructurada: “cuñalaNtros de medio Los funcionan vÉrdego por cuntrios sobre” Oración estructurada: “Los cuñalantros sobre cuntrios funcionan por medio de vérdego”. de 27

IC-t2 ESTRUCTURAS DE DATOS Tipos de datos básicos Un tipo de dato describe un conjunto de objetos con la misma representación. Escalares. Son aquellos en los que el conjunto de datos está ordenado y su valor es atómico Enteros. Conjunto de números enteros definidos por las matemáticas: {-1,-2,...} U {0,1,2,...} Carácter. Conjunto de valores definido en un alfabeto dado Booleano. Conjunto de valores definido por dos valores verdadero y falso, {true, false}. Real Ordinales. Subconjunto de los escalares. Son aquellos en los que cada valor tiene un único predecesor y un único sucesor Enteros Carácter Booleano (False, menor que true) de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos Modo de agrupación de los datos para que sean procesados (por las computadoras o por las personas) Al definir una operación, o ley de composición interna, en un conjunto de datos lo convertimos en una estructura, se convierte en algo más complejo que un mero conjunto de elementos. de 27

IC-t2 ESTRUCTURAS DE DATOS TAD = Tipo de datos + operaciones (II) Es un tipo especial de abstracción que involucra una descripción abstracta o lógica de los datos y de las operaciones definidas para un sistema Especificación: sintáctica y semántica Implementación: estructura de datos + algoritmos = programas. Se implementan mediante código No existe único TAD ideal capaz de ser el mejor para todos los casos. de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos. Clasificación (I) Tipos de datos básicos No se suelen incluir en las clasificaciones de TAD, aunque sí se pueden efectuar operaciones sobre ellos Enteros. Conjunto de números enteros definidos por las matemáticas: {-1,-2,...} U {0,1,2,...}. Las operaciones: suma, resta, multiplicación y división entera. Real. Conjunto de números reales definidos por las matemáticas y como operaciones: suma, resta, multiplicación y división. Carácter. Conjunto de valores definido en un alfabeto dado y como operaciones todos los operadores relacionales: <, >, =, <>... Booleano. Conjunto de valores definido por dos valores verdadero y falso, {true, false}. False, menor que true. Como operaciones, las definidas por el álgebra de Boole: AND, OR, NOT. de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos. Clasificación (II) Estáticas Básicas Arrays (arreglos) de una o varias dimensiones: vectores matrices, bidimensional cubos, tridimensional n dimensional Compuestas Registros Ficheros. Colecciones de registros de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos. Clasificación (III) Dinámicas Punteros Lineales Listas Pilas Colas, bicolas o dipolos Listas enlazadas, doblemente enlazadas y circulares No lineales, complejas Árboles Grafos, digrafos Conjuntos de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas Se dice que una estructura de datos es fundamental o estática cuando: Todos sus componentes son del mismo tipo Una vez definida, no se pueden crear nuevas variables ni alterar las ya definidas No es modificable durante la ejecución del programa Sirve de base para estructuras más complejas La cantidad de memoria ocupada debe ser declarada por anticipado y no podrá ser incrementada durante la ejecución del programa en el caso de que se necesite más. Se consideran estructuras estáticas las siguientes: “Arrays” o arreglos Los registros Los ficheros de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Arrays o arreglos. Array unidimensional, vector,array lineal o arreglo Array bidimensional, array de dos dimensiones, matriz o tabla Array tridimensional o cubo Array n-dimensional de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. “Arrays” Una colección de un número finito de N elementos del mismo tipo Características N es un número entero positivo Se gestionan por índices que son números enteros positivos. V(I) Se almacenan en memoria en orden creciente de sus índices en posiciones consecutivas Operaciones Búsqueda Inserción Borrado Ordenación Recorrido Mezcla de 27

IC-t2 A1 (6) A2 (9) A3 (12) A4 (13) ... An(15) ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Arrays. Ai (i = 1-N) Inserción Si lo que se desea es insertar un elemento al final del array, es una acción sencilla que se realiza siempre que haya área reservada en memoria. Si lo que se pretende es insertar un elemento en medio de otros dos, para conservar el orden, se deberá obligar a desplazarse una posición a todos los elementos posteriores al que se va a insertar, siempre y cuando las dimensiones del vector sean al menos una unidad mayor que el número de los elementos ocupados. Borrado de un elemento del array Si se desea borrar un elemento que está en la última posición no habrá ningún problema. Si se desea borrar un elemento intermedio, se deberá proceder, después del borrado, a desplazar los elementos que han quedado para que no haya huecos. Ordenación Se llama ordenación de un array a las operaciones necesarias para reorganizarlo, en sentido creciente o en sentido decreciente. A1 (6) A2 (9) A3 (12) A4 (13) ... An(15) de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Arrays. Ejemplo: Representar con ordinograma el siguiente supuesto: Introducir por teclado un parámetro M y el siguiente array A(I) e imprimir la suma de sus elementos positivos. de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Arrays. Ejemplo: Representar con ordinograma el siguiente supuesto: Introducir por teclado un parámetro M y un array A(I) e imprimir la suma de sus elementos positivos. 1 INICIO A(I) > 0 Sí Leer SUMA = SUMA + A(I) No A(I) I = 1,M No I = I + 1 I = M Sí “La suma de los elementos de A es:” SUMA Suma = 0 I= 1 FIN 1 de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Arrays. Ejemplo: Representar con ordinograma el siguiente supuesto: Leer la siguiente cadena de caracteres y obtener el número de veces que aparecen las letras “a”, “A”, “e”, “E”, “i”, “I” en la misma “Se hace una distinción entre técnicas y prácticas en función del propósito al que respondan, entendiendo por técnica el conjunto de heurísticas y procedimientos que se apoyan en estándares, utilizan una o varias notaciones específicas en términos de sintaxis y semántica y cumplen unos criterios de calidad en cuanto a la forma de obtención del producto asociado. Las prácticas representan un medio para la consecución de unos objetivos específicos de manera rápida, segura y precisa sin necesidad de cumplir unos criterios o reglas preestablecidas.” de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Matrices También llamadas Arrays de dos dimensiones o tablas MA (A= 1, M) * NB (B= 1,N) Colección de M*N elementos, donde M representa el número de filas que tiene la matriz y N el número de columnas y en la que se puede identificar a cada uno de los elementos por un par de índices (A,B), donde el primero (A) indica la fila y el segundo (B) la columna. Los índices son números enteros y han de cumplir que 1 <= A <= M y 1<= B <=N Estructuras estáticas con un límite preestablecido antes de la compilación. Se gestionan con dos índices de cualquier tipo ordinal Sobre este tipo de estructuras se realiza el mismo tipo de operaciones que sobre los arrays de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Matrices. Algunas aplicaciones Tablas de una base de datos relacional: Representación física de un tipo de entidad. Tablas de word (MS Office) En Excel, en Access (MS Office) En diversidad de técnicas: Análisis Coste/beneficio. Cálculo del retorno de la inversión y del valor actual de un bien Matriz Procesos/localización geográfica Matriz Almacenes de datos/entidades del modelo lógico de datos normalizado Matriz Entidades/procesos Matriz Entidades /eventos Matriz Objetos Diagrama de interacción/clases ... (en la metodologías de desarrollo se referencian más de 10 técnicas matriciales) En la Metodología multicriterio discreta: Evaluación de la mejor entre n alternativas considerando m criterios. Diagrama de Gantt de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Matrices. Tabla de una base de datos relacional. Tipo de Entidad. Cada fila una tupla u ocurrencia de entidad. Cada columna un atributo de 27

ESTRUCTURAS DE DATOS IC-t2 de 27

ESTRUCTURAS DE DATOS IC-t2 de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Matrices. Ejemplo: Realizar el ordinograma del siguiente supuesto: Introducir una matriz A (9,8), calcular e imprimir la suma de sus elementos de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Matrices. Ejemplo: Realizar el ordinograma de flujo del siguiente supuesto: Introducir una matriz A (9,8), calcular e imprimir la suma de sus elementos 1 INICIO SUMA = SUMA + A(I, J) Suma = 0 J=8 No J = J + 1 A(I, J) I = 1,9 J= 1, 8 Sí Sí Sí No I = 9 “La suma de los elementos de la Matriz es:” SUMA I= 1 I = I + 1 J= 1 FIN 1 de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Matrices. Ejemplo: Realizar el ordinograma (representación gráfica del algoritmo) del siguiente supuesto:Generar e imprimir una matriz M (10, 10) cuyo contenido sean las tablas de multiplicar de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Registros Tipo de datos estructurado estático compuesto por un número fijo de componentes no necesariamente del mismo tipo, denominados campos del registro y tal que a cada componente del registro se accede mediante un selector de campo. Conjunto de campos relacionados entre sí que tienen una unidad dentro del fichero. Son estructuras contempladas en todos los lenguajes de programación de alto nivel, es decir esos lenguajes disponen de palabras clave (RECORD) para su declaración y expresiones sintácticas para acceder a sus elementos (READ...). Lógico: Unidad de información homogénea. Puede ser de longitud fija o de longitud variable. Varios registros lógicos suelen dar lugar a uno físico (bloque). Frecuente Físico: Unidad de lectura/escritura en la computadora Varios registros físicos pueden dar lugar a uno lógico (expandido). Excepcional Cuando un registro físico y uno lógico coinciden, el factor de bloqueo = 1 de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Registros La longitud de un registro (no los campos del mismo) puede ser: Fija Variable Indefinida Las operaciones que se pueden realizar son: Consulta Inserción Borrado Modificación Clasificación Reorganización de 27

IC-t2 ESTRUCTURAS DE DATOS Estructuras de datos estáticas. Ficheros Estructura de datos estática que es el conjunto de varios registros. Conjunto de información (registros) homogénea y organizada referida a un mismo tema. Pueden almacenar: Programas (fuentes y objetos) Datos texto sonido voz imagen fija video ... Se estructuran en directorios mediante la descripción de una ruta o “path” Los directorios se encuentran dentro de discos físicos o unidades: C:/Mis documentos/universidad/cobol/programa1 de 27