Algoritmos de ordenación básicos

Tamaño: px
Comenzar la demostración a partir de la página:

Download "Algoritmos de ordenación básicos"

Transcripción

1 Algoritmos de ordenación básicos por Iván Cruz Cuando tratamos de resolver algunos problemas haciendo uso de la programación estructurada, en ocasiones es necesario poder ordenar un conjunto de datos. Ese ordenamiento puede requerir organizar la información de manera desendente o asendente, es decir, de mayor a menor o viceversa. Por ejemplo: Si se tiene un listado de promedios de un grupo de estudiantes y se desea contar con la información organizada en base a las calificaciones obtenidas, sería necesario ordenar los datos de acuerdo al rubro de promedio. Nombre Matrícula Promedio Juan Marín Vera Carolina Rey Masa Nora Raya Mares Tabla 1.- Datos deshordenados Nombre Matrícula Promedio Nora Raya Mares Juan Marín Vera Carolina Rey Masa Tabla 2.- Datos ordenados. Como podemos observar en las tablas anteriores, aparentemente realizar la ordenación para nosotros sería muy sencillo, sin embargo para llevar a cabo ese proceso dentro de un programa computacional las cosas se complican un poco, ya que sería necesario aplicar algunas operaciones de comparación e ir organizando poco a poco los datos. A través de esta lectura analizarás la forma de trabajar de algunos algoritmos que ya se encuentran desarrollados para llevar a cabo la ordenación de datos, así como su correspondiente codificación en lenguaje C. De acuerdo a Deitel (2004) existen varios algoritmos de ordenamiento entre los que podemos mencionar: heapsort, quicksort, mergesort, burbuja y burbuja mejorado. Todos estos algoritmos nos permiten ordenar datos, sin embargo el método burbuja es el más sencillo de implementar en un lenguaje de programación, aunque es considerado ineficiente, ya que es lento cuando se manejan grandes volúmenes de información. A continuación analizaremos el funcionamiento de las dos versiones del método burbuja. Algoritmo de ordenamiento burbuja El algoritmo de ordenamiento burbuja, es quizá el algoritmo de ordenamiento más ineficiente, pero a la vez es el fácil de implementar. 1

2 Su metodología se basa en comparar pares de números e ir intercambiando de lugar el número que sea mayor o menor según se esté ordenando de manera ascendente o descendente. Por lo tanto se compara uno por uno cada elemento del arreglo y se realizan intercambios de datos dentro del mismo arreglo si la condición planteada se cumple. En la Figura 1 se presenta de manera esquematizada como es que este algoritmo logra ordenar un conjunto de datos. Esta figura muestra que se deben utilizar n-1 iteraciones en una estructura de repetición, sabiendo de antemano que n representa el número total de elementos que posee el arreglo. Posteriormente se va realizando una comparación entre el valor de la posición actual con el valor de la posición contigua, en caso de requerir una ordenación ascendente la comparación se realiza con el signo de >, si se requiere el orden descendentemente el signo utilizado sería <, sólo en caso de que tal condición sea verdadera se procede al intercambio de los datos en las posiciones actuales del arreglo. Estos pasos se realizan de manera repetitiva hasta que se alcance la iteración final de la estructura de repetición utilizada. Figura 1. Esquema de trabajo del algoritmo de ordenamiento burbuja. El código fuente de este algoritmo se muestra en la Figura 2, el cual se divide en 4 segmentos 2

3 distinguibles como son, declaración de variables, ingreso de datos, método de la burbuja y despliegue de datos por pantalla. Figura 2. Código fuente en lenguaje C del algoritmo de ordenamiento burbuja. (Dev C++, 2005). a) Declaración de variables: se declararon 5 variables, la variable dimensión almacena el numero de posiciones de Arreglo que a su vez almacenará los datos ingresados por el usuario desde el teclado, la variable Temp, servirá para almacenar el valor de intercambio utilizado en la línea número 21, mientras que i así como también j, sólo se utilizan como índice de las estructuras de repetición utilizadas. b) Ingreso de datos por el teclado: En esta parte únicamente se reciben los datos que el usuario ingresa y son almacenados en su respectiva posición dentro de la variable Arreglo. c) Método de la burbuja: Este método utiliza 2 estructuras de repetición las cuales mientras que la primera controla el número de ocasiones que se repite el ordenamiento, la otra controla la comparación entre los datos posición por posición, mostrando además el procedimiento utilizado para realizar el intercambio de valores en caso de ser necesario. d) Despliegue de datos por pantalla: Únicamente se utiliza una estructura de repetición para desplegar por pantalla los datos almacenados en la variable Arreglo. Algoritmo de ordenamiento burbuja mejorado 3

4 El algoritmo de ordenamiento burbuja tiene como su principal desventaja, la cantidad de repeticiones que utiliza para ordenar un conjunto de datos, en la Figura 3, se presenta un esquema de la implementación que logra reducir en buena medida el tiempo computacional requerido por el método burbuja clásico, conocido como burbuja mejorado. Figura 3. Esquema de trabajo del algoritmo de ordenamiento burbuja mejorado. Se puede observar en la Figura 3, que en las iteraciones 2, 3 y 4, solo se realizo un solo intercambio de valores, lo que representa que de las 10 revisiones realizadas en total, solo son efectivas el 50% de ellas, lo que provoca un consumo de recursos innecesarios para la computadora, que se ve reflejado en el tiempo de espera del usuario, es importante resaltar que esto solo seria evidente ordenando una gran cantidad de datos. Aunque con la optimización que representa la burbuja mejorada, en este caso, solamente se redujo al 90% de las revisiones, lo cual implica un 10% de mejoría en el proceso del método, esta característica estiba en el hecho de que al no presentarse un solo intercambio en toda una iteración, entonces ya no existirá ningún cambio en el futuro debido a que ya se encuentran ordenados, esta característica seria muy benéfica en el caso en el que el usuario sin conocer los datos a ordenar, estos ya estuvieran ordenados, lo cual reduciría enormemente los cálculos computacionales. 4

5 Para analizar más técnicamente la característica distintiva entre estos 2 algoritmos se presenta el código fuente correspondiente a la burbuja mejorada en la Figura 4. Figura 4. Código fuente en lenguaje C del algoritmo de ordenamiento burbuja mejorado. (Dev C++, 2005). El código fuente de esta figura se puede analizar tomando en consideración los 4 aspectos fundamentales siguientes: 5

6 a) Declaración de variables: Únicamente se agregó la variable de tipo int bandera inicializada en cero. b) Ingreso de datos por el teclado: permanece exactamente igual que en el método de burbuja clásico. c) Método de burbuja mejorado: La gran aportación de este método radica en la variable declarada como bandera, la cual revisa en cada iteración si existió mínimo un intercambio de valores, si esto es cierto se reinicializa en cero para seguir cumpliendo con su tarea de verificación asignada. Si en la iteración que se encuentra verificando dicha variable se registra que no existió ningún intercambio de valores en el arreglo entonces eso significa que el arreglo ya se encuentra ordenado y por lo cual la variable bandera hace cumplir la condición de la estructura condicional if y se ejecuta la sentencia break, que termina la ejecución del ciclo, y por lo tanto el método ha llegado a su fin, dando paso al despliegue de datos por pantalla. d) Despliegue de datos por pantalla: permanece exactamente igual que en el método de burbuja clásico. Conclusión. A través de esta lectura se analizaron 2 algoritmos de ordenamiento conocidos como burbuja y burbuja mejorado, los cuales sirven como antes ala para poder comprender y realizar métodos de ordenamiento más complejos, eficaces y veloces tales como quicksort o mergesort por mencionar algunos. El problema de ordenar ascendente y/o descendentemente un conjunto de datos cobra importancia al realizar aplicaciones de sistemas de información, en las que el poder manipular grandes cantidades de datos es una actividad constante, motivo por el cual debe ser realizada de forma efectiva, confiable y veloz. Referencias Deitel, M. (2004). Cómo programar en C/C++ y Java (4ª. Ed.). México: Pearson Educación. [Versión en línea]. Recuperado el 29 de julio de 2010, de la base de datos de Bibliotechnia. Recurso disponible en la Biblioteca Digital de la UVEG. Sedgewick, R. (2000). Algoritmos en C++ (1ª. Ed.). México: Addison Wesley Longman. [Versión en línea]. Recuperado el 29 de julio de 2010, de la base de datos de Bibliotechnia. Recurso disponible en la Biblioteca Digital de la UVEG. Dev C++. (2005). Dev C++ (Ver. 5 ( )). Recuperado el 29 de julio de 2010 de Software utilizado bajo licencia GPL. 6

Cómo implementar tus propias funciones en Lenguaje C?

Cómo implementar tus propias funciones en Lenguaje C? Cómo implementar tus propias funciones en Lenguaje C? por Iván Cruz Cuando se realiza un programa, es importante siempre manejar una buena organización del código fuente, debido a que se puede desear incrementar

Más detalles

Escribir programas a partir de un diagrama de flujo

Escribir programas a partir de un diagrama de flujo Escribir programas a partir de un diagrama de flujo por Iván Cruz En esta lectura se revisará una estrategia específica para lograr implementar un programa computacional a partir de un diagrama de flujo,

Más detalles

Sintaxis de los aspectos generales de un lenguaje de programación

Sintaxis de los aspectos generales de un lenguaje de programación Sintaxis de los aspectos generales de un lenguaje de programación por Iván Cruz Un lenguaje de programación cuenta con una estructura y sintaxis que debe ser utilizada exactamente como se indique para

Más detalles

Recursividad. Figura 1. Cálculo del factorial de un número determinado.

Recursividad. Figura 1. Cálculo del factorial de un número determinado. Recursividad La recursividad es una metodología de programación que en la práctica suele ser muy compleja, es por ello que este tema es tratado en cursos universitarios de programación avanzada. Por lo

Más detalles

CAPÍTULO 3 ESTRUCTURAS DE DATOS ESTÁTICAS

CAPÍTULO 3 ESTRUCTURAS DE DATOS ESTÁTICAS CAPÍTULO 3 ESTRUCTURAS DE DATOS ESTÁTICAS Capítulo 3 Estructuras de datos estáticas 1/37 1. INTRODUCCIÓN Las estructuras de datos se utilizan, generalmente, para procesar una colección de valores que están

Más detalles

ESTRUCTURA DE DATOS: Tema 5. Ordenamiento y Búsqueda

ESTRUCTURA DE DATOS: Tema 5. Ordenamiento y Búsqueda ESTRUCTURA DE DATOS: Tema 5. Ordenamiento y Búsqueda Presenta: David Martínez Torres Universidad Tecnológica de la Mixteca Instituto de Computación Oficina No. 37 [email protected] Contenido 1. Ordenamiento

Más detalles

Este método se basa en buscar el elemento menor el vector y colocarlo en la primera

Este método se basa en buscar el elemento menor el vector y colocarlo en la primera Lectura ORDENACIÓN DE ARREGLOS Con frecuencia se requiere clasificar u ordenar los elementos de un vector (arreglo unidimensional) en algún orden en particular. Por ejemplo, ordenar un conjunto de números

Más detalles

EI MT1008 Programación II

EI MT1008 Programación II GRADO EN INGENIERÍA INFORMÁTICA GRADO EN MATEMÁTICA COMPUTACIONAL EI1008 - MT1008 Programación II Curso 2010-2011 Departamento de Lenguajes y Sistemas Informáticos 1. Datos de la asignatura Carácter: Formación

Más detalles

Métodos de Ordenamiento

Métodos de Ordenamiento Métodos de Ordenamiento Muchas veces es necesario además de buscar elementos dentro de en un vector, ordenarlos. El ordenamiento puede ser de mayor a menor si se están manejando números y en orden alfabético

Más detalles

INFORMATICA TECNICATURA DE NIVEL SUPERIOR ALGUNOS EJERCICIOS DE SELECCIÓN E ITERACION

INFORMATICA TECNICATURA DE NIVEL SUPERIOR ALGUNOS EJERCICIOS DE SELECCIÓN E ITERACION INFORMATICA TECNICATURA DE NIVEL SUPERIOR ALGUNOS EJERCICIOS DE SELECCIÓN E ITERACION DIIAGRAMAS DE FLUJO Un diagrama de flujo es un dibujo que utiliza símbolos estándar de diagramación de algoritmos para

Más detalles

Métodos de Ordenamiento. Unidad VI: Estructura de datos

Métodos de Ordenamiento. Unidad VI: Estructura de datos Métodos de Ordenamiento Unidad VI: Estructura de datos Concepto de ordenación La ordenación de los datos consiste en disponer o clasificar un conjunto de datos (o una estructura) en algún determinado orden

Más detalles

7.1 Consideraciones. Considere la búsqueda de un libro en una biblioteca. Considere la búsqueda de un nombre en el directorio telefónico.

7.1 Consideraciones. Considere la búsqueda de un libro en una biblioteca. Considere la búsqueda de un nombre en el directorio telefónico. 86 Capítulo 7. ORDENAMIENTO. 7.1 Consideraciones. Considere la búsqueda de un libro en una biblioteca. Considere la búsqueda de un nombre en el directorio telefónico. Si los elementos a ordenar son compuestos

Más detalles

Lenguajes de programación

Lenguajes de programación Lenguajes de programación por Iván Cruz A través de la historia, el hombre siempre ha buscado la manera de comunicarse con otros seres vivos, debido a ello se crearon diversas formas de comunicación, tales

Más detalles

Cómo describir un diagrama de flujo en pseudocódigo?

Cómo describir un diagrama de flujo en pseudocódigo? Cómo describir un diagrama de flujo en pseudocódigo? Por: Iván Cruz Aceves Antes de utilizar un lenguaje de programación, es necesario estructurar algoritmos y diagramas de flujo de tal manera que cuando

Más detalles

Diagramas de flujo. Ejemplo 1. Algoritmo para sumar dos números

Diagramas de flujo. Ejemplo 1. Algoritmo para sumar dos números Diagramas de flujo Por: Iván Cruz Aceves Para desarrollar un programa informático se requiere, en primera instancia, conocer el problema y plantear una solución. Para ello, es necesario crear un algoritmo

Más detalles

Estructura de datos. Carrera: SCC Participantes

Estructura de datos. Carrera: SCC Participantes 1.- DATOS DE LA ASIGNATURA Nombre de la asignatura: Carrera: Clave de la asignatura: Horas teoría-horas práctica-créditos Estructura de datos Ingeniería en Sistemas Computacionales SCC - 0408 4-2-10 2.-

Más detalles

Unidad 3. Estructuras de control en diagrama de Flujo y pseudocódigo Tema Iteración o Repetitivas (repite - mientras) Juan Pablo Cobá Juárez Pegueros

Unidad 3. Estructuras de control en diagrama de Flujo y pseudocódigo Tema Iteración o Repetitivas (repite - mientras) Juan Pablo Cobá Juárez Pegueros Unidad 3. Estructuras de control en diagrama de Flujo y pseudocódigo Tema Iteración o Repetitivas (repite - mientras) Juan Pablo Cobá Juárez Pegueros Programación Básica Bioingeniería Médica Facultad de

Más detalles

Versatilidad de la estructura de repetición for

Versatilidad de la estructura de repetición for Versatilidad de la estructura de repetición for por Iván Cruz La estructura de repetición for puede emplearse para una infinidad de tareas, una de ellas es poder utilizarla para el ingreso de datos consecutivamente

Más detalles

Universidad Salesiana de Bolivia

Universidad Salesiana de Bolivia Universidad Salesiana de Bolivia Ingeniería de Sistemas I II PLAN DE DISCIPLINA GESTIÓN I - 2016 DATOS DE IDENTIFICACIÓN INSTITUCIÓN UNIVERSITARIA: Universidad Salesiana de Bolivia RECTOR: Dr. Rvdo. P.

Más detalles

Operadores. Java es un lenguaje rico en operadores, que son casi idénticos a los de C/C++.

Operadores. Java es un lenguaje rico en operadores, que son casi idénticos a los de C/C++. Operadores Java es un lenguaje rico en operadores, que son casi idénticos a los de C/C++. Operadores aritméticos Son operadores binarios (requieren siempre dos operandos) que realizan las operaciones aritméticas

Más detalles

Unidad 3. Estructuras de control en diagrama de Flujo y pseudocódigo Tema Iteración o Repetitivas (mientras)

Unidad 3. Estructuras de control en diagrama de Flujo y pseudocódigo Tema Iteración o Repetitivas (mientras) Juan Pablo Cobá Juárez Pegueros Programación Básica Bioingeniería Médica Facultad de Medicina Unidad 3. Estructuras de control en diagrama de Flujo y pseudocódigo Tema Iteración o Repetitivas (mientras)

Más detalles

Estructura repetitiva while

Estructura repetitiva while Estructura repetitiva while Hasta ahora hemos empleado estructuras SECUENCIALES y CONDICIONALES. Existe otro tipo de estructuras tan importantes como las anteriores que son las estructuras REPETITIVAS.

Más detalles

Cómo escribir algoritmos?

Cómo escribir algoritmos? Cómo escribir algoritmos? Por: Iván Cruz Aceves Algoritmos En tu rutina diaria realizas una gran diversidad de tareas, por ejemplo, bañarte, vestirte, desayunar, ir al trabajo o a la escuela, ir a comer,

Más detalles

Universidad Tecnológica Nacional Facultad Regional San Francisco. Tecnicatura Superior en Programación PROGRAMACIÓN II

Universidad Tecnológica Nacional Facultad Regional San Francisco. Tecnicatura Superior en Programación PROGRAMACIÓN II Universidad Tecnológica Nacional Facultad Regional San Francisco Tecnicatura Superior en Programación PLANIFICACIÓN CICLO LECTIVO 2014 ÍNDICE ÍNDICE... 2 PROFESIONAL DOCENTE A CARGO... 3 UBICACIÓN... 4

Más detalles

PLANTILLA DE LA GUÍA DIDÁCTICA DE LA ASIGNATURA

PLANTILLA DE LA GUÍA DIDÁCTICA DE LA ASIGNATURA PROGRAMA ACADÉMICO: Ingeniería Informática ASIGNATURA: Fundamentos de Programación 1 CÓDIGO DE ASIGNATURA: ING00010 GRUPO: 25 25A FECHA DE INICIO: Agosto 8 de 2016 PROFESOR: Sandra Mateus, Ph.D E mail:

Más detalles

Programación Estructurada

Programación Estructurada Programación Estructurada Técnica de programación que consiste en construir programas de fácil comprensión. Es mucho más sencillo entender la codificación del programa, que se habrá hecho en diferentes

Más detalles

Subdirección Académica Instrumentación Didáctica para la Formación y Desarrollo de Competencias Profesionales Periodo escolar: Agosto Diciembre 2017

Subdirección Académica Instrumentación Didáctica para la Formación y Desarrollo de Competencias Profesionales Periodo escolar: Agosto Diciembre 2017 Subdirección Académica Instrumentación Didáctica para la Formación y Desarrollo de s Profesionales Periodo escolar: Agosto Diciembre 2017 Nombre de la asignatura: Fundamentos de Programación Plan de estudios:

Más detalles

Computadora y Sistema Operativo

Computadora y Sistema Operativo Computadora y Sistema Operativo Según la RAE (Real Academia de la lengua española), una computadora es una máquina electrónica, analógica o digital, dotada de una memoria de gran capacidad y de métodos

Más detalles

En los siguientes ejemplos, usarás Solver para resolver los modelos y problemas de programación lineal planteados. 1 + x 2

En los siguientes ejemplos, usarás Solver para resolver los modelos y problemas de programación lineal planteados. 1 + x 2 II000_MAAL3_Ejemplos Versión: Septiembre 0 Ejemplos con Solver por Oliverio Ramírez En los siguientes ejemplos, usarás Solver para resolver los modelos y problemas de programación lineal planteados. Ejemplo

Más detalles

Eduardo Andrés Medina Ramírez Angel Robles Pérez MÉTODO DE ORDENAMIENTO QUICKSORT

Eduardo Andrés Medina Ramírez Angel Robles Pérez MÉTODO DE ORDENAMIENTO QUICKSORT Eduardo Andrés Medina Ramírez Angel Robles Pérez MÉTODO DE ORDENAMIENTO QUICKSORT QUÉ ES QUICKSORT? HISTORIA DEL MÉTODO QUICKSORT El método Quicksort fue ideado por el científico inglés Charles Anthony

Más detalles

Calendario Académico año Introducción a la Programación I

Calendario Académico año Introducción a la Programación I Calendario Académico año 2012 Introducción a la Programación I Febrero 14 Martes Febrero 16 Jueves Tema: Bienvenida y presentación del curso. Prueba Diagnóstica. Febrero 21 Tema: Continuación Introducción

Más detalles

Programación I. Carrera: ECM Participantes Participantes de las academias de ingeniería electrónica de los Institutos Tecnológicos.

Programación I. Carrera: ECM Participantes Participantes de las academias de ingeniería electrónica de los Institutos Tecnológicos. .- DATOS DE LA ASIGNATURA Nombre de la asignatura: Carrera: Clave de la asignatura: Horas teoría-horas práctica-créditos Programación I Ingeniería Electrónica. ECM-043 3-2- 2.- HISTORIA DEL PROGRAMA Lugar

Más detalles

SILABO DEL CURSO FUNDAMENTOS DE PROGRAMACIÓN

SILABO DEL CURSO FUNDAMENTOS DE PROGRAMACIÓN FACULTAD DE INGENIERÍA CARRERA DE INGENIERÍA DE SISTEMAS SILABO DEL CURSO FUNDAMENTOS DE PROGRAMACIÓN 1. DATOS GENERALES 1.1. Facultad : Ingeniería 1.2. Carrera Profesional : Ingeniería de Sistemas 1.3.

Más detalles

Tema: Vectores en C#

Tema: Vectores en C# Facultad: Ingeniería Escuela: Ingeniería en Computación Asignatura: Programación Estructurada Objetivos Tema: Vectores en C# Introducir al estudiante a los conceptos de estructura de datos. Conocer la

Más detalles

UNIVERSIDAD AUTÓNOMA DE CHIAPAS Facultad de Contaduría y Administración, Campus I

UNIVERSIDAD AUTÓNOMA DE CHIAPAS Facultad de Contaduría y Administración, Campus I Programa descriptivo por unidad de competencia Programa educativo Licenciatura en Ingeniería en Desarrollo y Tecnologías de Software Modalidad Presencial Clave IS02 H S M Horas Unidad de Teoría Práctica

Más detalles

Universidad de Valladolid. Departamento de informática. Campus de Segovia. Estructura de datos Tema 4: Ordenación. Prof. Montserrat Serrano Montero

Universidad de Valladolid. Departamento de informática. Campus de Segovia. Estructura de datos Tema 4: Ordenación. Prof. Montserrat Serrano Montero Universidad de Valladolid Departamento de informática Campus de Segovia Estructura de datos Tema 4: Ordenación Prof. Montserrat Serrano Montero ÍNDICE Conceptos básicos Elección de un método Métodos directos

Más detalles

Análisis de rendimiento de algoritmos paralelos

Análisis de rendimiento de algoritmos paralelos Análisis de rendimiento de algoritmos paralelos Joaquín Andrés López Molina [email protected] Daniel Mauricio Rodríguez Alpizar [email protected] Estudiantes de Ingeniería en Computación

Más detalles

PRESENTACIÓN DEL ALGORITMO

PRESENTACIÓN DEL ALGORITMO PRESENTACIÓN DEL ALGORITMO Puede ser en distintas formas, analizaremos cuatro: a) Descripción Narrada b) Pseudocódigo c) Diagramas de Flujo d) Diagramas N- S (Nassi-Schneiderman o de Chapin) Descripción

Más detalles

SYLLABUS de la Asignatura. Programación INF1201

SYLLABUS de la Asignatura. Programación INF1201 Sazie 2325, 3er Piso, Santiago +56 2 661 8256 SYLLABUS de la Asignatura Programación INF1201 1. Descripción de la asignatura El estudiante aprenderá a analizar un problema y plantear una solución racionalmente,

Más detalles

PROGRAMA ANALÍTICO DE ASIGNATURA

PROGRAMA ANALÍTICO DE ASIGNATURA UNIVERSIDAD AUTÓNOMA DEL ESTADO DE HIDALGO COORDINACIÓN DE DOCENCIA DIRECCIÓN DE PLANEACIÓN Y DESARROLLO EDUCATIVO PROGRAMA ANALÍTICO DE ASIGNATURA 1.- DATOS GENERALES 1.1 INSTITUTO: Instituto de Ciencias

Más detalles

Algoritmos de Ordenamiento

Algoritmos de Ordenamiento Algoritmos de Ordenamiento mat-151 Alonso Ramírez Manzanares Computación y Algoritmos 12.04 Algoritmos de ordenamiento Entrada: secuencia de números. Salida: permutación

Más detalles

Tema: Vectores en C#.

Tema: Vectores en C#. Facultad: Ingeniería Escuela: Ingeniería en Computación Asignatura: Programación Estructurada Tema: Vectores en C#. Objetivos Introducir al estudiante a los conceptos de estructura de datos. Conocer la

Más detalles

TEMA 1. PROGRAMACIÓN DE UN COMPUTADOR

TEMA 1. PROGRAMACIÓN DE UN COMPUTADOR Tema 1. Programación de un computador TEMA 1. CIÓN DE UN COMPUTADOR 1. CONCEPTO DE 2. LENGUAJES DE CIÓN 2.1. LENGUAJE MÁQUINA 2.2. LENGUAJE ENSAMBLADOR 2.3. LENGUAJE DE ALTO NIVEL 3. ALGORITMOS. REPRESENTACIÓN

Más detalles

Tema: Métodos de Ordenamiento. Parte 3.

Tema: Métodos de Ordenamiento. Parte 3. Programación IV. Guía No. 5 1 Facultad: Ingeniería Escuela: Computación Asignatura: Programación IV Tema: Métodos de Ordenamiento. Parte 3. Objetivos Específicos Identificar la estructura de algunos algoritmos

Más detalles

Programación. Carrera: MAE 0527

Programación. Carrera: MAE 0527 1.- DATOS DE LA ASIGNATURA Nombre de la asignatura: Carrera: Clave de la asignatura: Horas teoría-horas práctica-créditos: Programación Ingeniería en Materiales MAE 0527 2 2 6 2.- HISTORIA DEL PROGRAMA

Más detalles

OLIMPIADA DE INFORMÁTICA DEL ESTADO DE JALISCO. Problemando Avanzado de C++

OLIMPIADA DE INFORMÁTICA DEL ESTADO DE JALISCO. Problemando Avanzado de C++ OLIMPIADA DE INFORMÁTICA DEL ESTADO DE JALISCO Problemando Avanzado de C++ El presente problemario está diseñado con la finalidad de dar a los principiantes en programación una serie de retos básico que

Más detalles

Algoritmo, Estructuras y Programación I Ing. Marglorie Colina

Algoritmo, Estructuras y Programación I Ing. Marglorie Colina Unidad II: Fundamentos de la Programación Estructurada Algoritmo, Estructuras y Programación I Ing. Marglorie Colina Estructura General de un Programa Zona de ficheros de cabecera de las librerías Zona

Más detalles

FACULTAD DE INGENIERÍA DEPARTAMENTO DE INGENIERÍA DE SISTEMAS. Horas Contacto. Objetivos

FACULTAD DE INGENIERÍA DEPARTAMENTO DE INGENIERÍA DE SISTEMAS. Horas Contacto. Objetivos FACULTAD DE INGENIERÍA DEPARTAMENTO DE INGENIERÍA DE SISTEMAS Nombre de la asignatura (Curso) Código de la asignatura (ID Curso) Pensamiento Algorítmico 4206 Fecha de Actualización 21 de Julio de 2011

Más detalles

Centro Universitario UAEM Zumpango! Ingeniería en Computación! Programación estructurada

Centro Universitario UAEM Zumpango! Ingeniería en Computación! Programación estructurada Centro Universitario UAEM Zumpango!! Agosto 2015 Identificación de la Unidad de Aprendizaje (UA) Nombre UA: Programación esctructurada (L41012) Total de horas a la semana: 6 Créditos: 9 Carácter de la

Más detalles

TEMA 5. ESTRUCTURAS DE CONTROL: BUCLES.

TEMA 5. ESTRUCTURAS DE CONTROL: BUCLES. TEMA 5. ESTRUCTURAS DE CONTROL: BUCLES. Una de las características de las computadoras que aumenta considerablemente su potencia es su capacidad para ejecutar una tarea muchas (repetidas) veces con gran

Más detalles

Tema: Métodos de Ordenamiento. Parte 1.

Tema: Métodos de Ordenamiento. Parte 1. Programación IV. Guía No. 3 1 Facultad: Ingeniería Escuela: Computación Asignatura: Programación IV Tema: Métodos de Ordenamiento. Parte 1. Objetivos Específicos Identificar la estructura de algunos algoritmos

Más detalles

Carrera: EMZ Participantes Representante de las academias de ingeniería Electromecánica de los Institutos Tecnológicos.

Carrera: EMZ Participantes Representante de las academias de ingeniería Electromecánica de los Institutos Tecnológicos. 1.- DATOS DE LA ASIGNATURA Nombre de la asignatura: Carrera: Clave de la asignatura: Horas teoría-horas práctica-créditos Introducción a la Programación Ingeniería Electromecánica EMZ - 0522 1-3- 5 2.-

Más detalles

SÍLABO DE ESTRUCTURA DE DATOS

SÍLABO DE ESTRUCTURA DE DATOS SÍLABO DE ESTRUCTURA DE DATOS I. DATOS GENERALES 1.1. Carrera Profesional : Ingeniería de Sistemas 1.2. Área Académica : Ingeniería de Sistemas 1.3 Ciclo : III 1.4. Semestre : 2014-I 1.5. Prerrequisito

Más detalles

ALGORITMOS, ESTRUCTURAS Y PROGRAMACION

ALGORITMOS, ESTRUCTURAS Y PROGRAMACION VICERRECTORADO ACADÉMICO DIRECCIÓN DE GESTIÓN, DESARROLLO E INNOVACIÓN CURRICULAR FACULTAD: INGENIERIA ESCUELAS: COMPUTACION - SISTEMA UNIDAD CURRICULAR: ALGORITMOS, ESTRUCTURAS Y PROGRAMACION FECHA DE

Más detalles

La resolución de problemas es una tarea únicamente humana comprobable en todos los casos con los mismos resultados.

La resolución de problemas es una tarea únicamente humana comprobable en todos los casos con los mismos resultados. Pseudocódigo Introducción La importancia de sistematizar procesos y crear programas de cómputo radica esencialmente en que estos se puedan utilizar como resolución de problemas similares en muchos casos,

Más detalles

Planificaciones Algoritmos y Programación I. Docente responsable: CARDOZO MARTIN MIGUEL. 1 de 7

Planificaciones Algoritmos y Programación I. Docente responsable: CARDOZO MARTIN MIGUEL. 1 de 7 Planificaciones 7502 - Algoritmos y Programación I Docente responsable: CARDOZO MARTIN MIGUEL 1 de 7 OBJETIVOS Capacitar al alumno en el diseño y programación documentados de algoritmos y en la elección

Más detalles

Nombre de la asignatura: Diseño Estructurado de Algoritmos. Carrera: Ingeniería en Sistemas Computacionales. Clave de la asignatura: SCB-9316

Nombre de la asignatura: Diseño Estructurado de Algoritmos. Carrera: Ingeniería en Sistemas Computacionales. Clave de la asignatura: SCB-9316 . D A T O S D E L A A S I G N A T U R A Nombre de la asignatura: Diseño Estructurado de Algoritmos Carrera: Ingeniería en Sistemas Computacionales Clave de la asignatura: SCB-9 Horas teoría Horas práctica

Más detalles

Planificaciones Algoritmos y Programación I. Docente responsable: CARDOZO MARTIN MIGUEL. 1 de 8

Planificaciones Algoritmos y Programación I. Docente responsable: CARDOZO MARTIN MIGUEL. 1 de 8 Planificaciones 9511 - Algoritmos y Programación I Docente responsable: CARDOZO MARTIN MIGUEL 1 de 8 OBJETIVOS Capacitar al alumno en el diseño y programación documentados de algoritmos y en la elección

Más detalles

23. Ordenación de vectores (tablas) Diego Gutiérrez

23. Ordenación de vectores (tablas) Diego Gutiérrez 23. Ordenación de vectores (tablas) 1 O cómo evitar tener que buscar una aguja en un pajar Ordenación 3 Ordenación O cómo evitar tener que buscar una aguja en un pajar Cómo buscamos una palabra en un diccionario?

Más detalles

SILABO DEL CURSO ALGORITMOS Y ESTRUCTURAS DE DATOS 1

SILABO DEL CURSO ALGORITMOS Y ESTRUCTURAS DE DATOS 1 FACULTAD DE INGENIERIA CARRERA DE INGENIERIA DE SISTEMAS SILABO DEL CURSO ALGORITMOS Y ESTRUCTURAS DE DATOS 1 1. DATOS GENERALES 1.1. Facultad : Ingeniería 1.. Carrera Profesional : Ingeniería de Sistemas

Más detalles