Download Algoritmos y Programación - Universidad del Magdalena

Document related concepts

Axiom wikipedia , lookup

J (lenguaje de programación) wikipedia , lookup

Programación funcional wikipedia , lookup

Transcript
Universidad del Magdalena
Vicerrectoría de Docencia
Microdiseño Algoritmos y Programación
1 Ficha de Identificación
1.1
Código y Nombre del Curso
Algoritmos y Programación
1.2
Unidad Académica Responsable del Curso
Ingeniería de Sistemas
1.3
Ubicación curricular
Componente Curricular
Pre-Requisitos
Co-Requisitos
Algoritmos y Programación
1.4
1.5
Créditos Académicos
Créditos
HAD
HTI
Proporción HAD:HTI
4
64
128
1:2
Descripción resumida del curso
Este curso suscita su justificación en el hecho de que se debe fomentar en el alumnado las
competencias iniciales o previas en el área de programación de computadores como elemento
disciplinar del ingeniero de sistemas. el proceso formativo del ingeniero de sistemas, requiere como
elemento de formación básica, el conocimiento de los diferentes paradigmas de programación y sus
modelos computacionales; de forma tal que el Objetivo primordial del curso está en valorar la
importancia del diseño de algoritmos para resolver problemas concretos expresándolos
estructuralmente, utilizando el ambiente de programación para editar, compilar y ejecutar un
programa en el computador y como curso de iniciación de ingeniería aplicada, los estudiantes podrán
situar los fundamentos para adelantar cursos más avanzados de programación y estructuración de
datos. A nivel de competencias le permitirá al estudiante identificar y seleccionar los elementos e
instrucciones de los lenguajes de programación para dar solución a problemas por medio de
programas de cómputo. Se puede
El conjunto de temáticas del curso lo comprende: las definiciones de algoritmos y lenguajes,
instrucciones de secuencia, condicionales y cíclicas, arreglos y cadenas, funciones, punteros y
archivos. Finalmente, la evaluación será permanente, con el fin de retroalimentar el proceso de
aprendizaje, para que permita al estudiante conocer sus potencialidades y debilidades, cómo mejorar
y continuar con éxito el mismo.
Página 1 de 6
Vicerrectoría de Docencia
Microdiseño
1.6
Elaboración, Revisión y Aprobación
Elaboró
Revisó
Aprobó
Eduardo Ropain Munive
2 Justificación
En estos momentos, los cambios sorprendentes que sufre el mundo a nivel tecnológico, cultural,
social, científico, lleva al hombre a prepararse y aceptar los retos que se le presentan. Es por eso
que nuestros futuros ingenieros de sistemas tienen que recibir una formación idónea, que les permita
ser competitivos en el mercado y agentes solucionadores de problemas de su entorno local, nacional
e internacional.
En el proceso formativo del Ingeniero de Sistemas se promueve el desarrollo y fortalecimiento de
habilidades que le permiten hacer planteamientos y dar soluciones efectivas a problemas complejos,
fomentando el trabajo en equipo, la flexibilidad, el pensamiento y actitud crítica, así como el desarrollo
de habilidades en comunicación oral y escrita. Se requiere de esta asignatura porque se deben
fomentar en el alumnado las competencias iniciales o previas en el área de programación de
computadores como elemento disciplinar del ingeniero de sistemas. el proceso formativo del
ingeniero de sistemas, requiere como elemento de formación básica, el conocimiento de los
diferentes paradigmas de programación y sus modelos computacionales.
La asignatura Algoritmos y Programación le sirve a los estudiantes de ingeniería de sistemas para
construir conceptos básicos, tales como algoritmos, estructura de datos, así como el modo de
aprender a solucionar problemas mediante el uso de computadores, los cuales suelen ser vitales
debido a la trascendencia que un aprendizaje gradual y correcto supondrá para su carrera y sobre
todo para la iniciación en el área de programación o construcción de programas de aplicación. El
control de las técnicas básicas de programación de algoritmos es una herramienta fundamental para
adquirir el dominio de la descomposición de problemas y plantear una solución posible y eficiente. Es
crítico para cualquier ingeniero poder definir estrategias de solución con orden, secuencia y análisis
profundo de la naturaleza del problema planteado, y generar un modelo que pueda ser solución a una
necesidad cualquiera.
3 Competencias a Desarrollar
3.1
Competencias Genéricas
Aplicar conocimientos en cuanto a metodologías y herramientas de programación de computadores
para el análisis y solución de problemas referentes al desarrollo de sistemas informáticos.
El estudiante identifica y selecciona los elementos e instrucciones de los lenguajes de programación
para dar solución a problemas por medio de programas de computo
Página 2 de 6
Vicerrectoría de Docencia
Microdiseño
3.2
Competencias Específicas
Desarrollar el pensamiento lógico-matemático.
Aplicar conocimientos para analizar y dar soluciones tecnológicas a las solicitudes de desarrollo
de sistemas computacionales.
Diseñar soluciones a problemas por medio de programas de cómputo.
Conocimiento y aplicación de herramientas y lenguajes de programación.
Implementar programas de cómputo.
Descomposición de problemas.
Identificar soluciones que encajen con soluciones conocidas para determinados problemas y
adaptarlas a casos particulares.
4 Contenido y Estimación de Créditos Académicos
Unidades Temáticas
N
1
Nombre
Algoritmo y lenguaje de programación
Temas
N
Características del algoritmo
1.2
Tipos de Lenguajes
1.3
Historia y Características del Lenguaje
Introducción a los lenguajes
2.2.
2.3.
Instrucciones de Entrada y Salida
2.4
Asignación
4.1
Instrucciones Condicionales: if-else, switch,
centinela
Instrucciones de Repetición: while, do-while,
for
Arreglos Unidimensionales: Vectores
4.2.
Arreglos Multidimensionales: Matrices
4.3.
Cadenas de Caracteres
4.4.
Estructuras de Datos
5.1
Definición y Llamada
5.2
Prototipos
5.3
Variables y Parámetros
5.4
Paso de Parámetros
3.1.
3
Instrucciones condicionales y ciclicas
3.2.
4
5
Arreglos y Cadenas
Funciones
6.2
Definición, Declaración y Asignación
Direcciones
Indirección
6.3
Operaciones con Punteros
6.4
Punteros y Tablas
6.5
Punteros y Estructuras
7.1
Abrir y Cerrar Archivos
7.2
Archivos de Acceso Secuencial
7.3
Archivos de Acceso Directo
7.4
Manipulación de Archivos
6.1
6
7
Punteros
Archivos
Estructura de un Programa
Tipos de Datos, Identificadores, Variables y
Constantes
Expresiones
2.1.
2
Nombre
1.1
1.4
Tiempos
de
HAD
T
P
T
HTI
P
1
0
0
1
0
0
0
0
1
1
1
1
0
3
0
3
2
4
1
5
1
1
1
1
1
1
1
1
1
0
1
0
0
2
4
4
3
4
7
6
1
3
1
6
11
1
1
0
1
1
1
0
1
1
3
2
2
2
2
2
2
1
2
1
1
1
1
1
1
1
1
1
6
5
5
5
4
5
5
4
5
11
9
8
9
8
9
8
7
9
1
1
1
1
1
0
1
1
1
1
1
3
2
2
2
2
2
2
0
1
1
1
0
1
0
1
0
5
4
5
5
4
5
4
5
4
7
7
10
9
7
8
7
9
7
Total
Página 3 de 6
Vicerrectoría de Docencia
Microdiseño
Unidades Temáticas
N
Temas
Nombre
N
Tiempos
HAD
T
P
Nombre
Total
22
Créditos Académicos
42
HTI
T
P
21
107
Total
192
4
5 Propuesta Metodológica
Exposición en clase: El docente proporcionará los conceptos básicos a tratar en la cátedra.
Trabajos dirigidos: Se asignarán a los estudiantes individual y grupalmente actividades que
desarrollarán durante la clase o como trabajo extra-clase, basados en los temas vistos.
Consultas bibliográficas: Se asignarán a los estudiantes tareas de consultas las cuales luego
serán socializadas para la validación de los conceptos trabajados.
Trabajos prácticos: Algunas sesiones serán desarrolladas en el Laboratorio de Sistemas con el
fin realizar ejercicios de resolución de problemas que ayuden a la asimilación de los puntos
principales que se hayan visto en clase.
6 Estrategias y Criterios de Evaluación
La evaluación será permanente, con el fin de retroalimentar el proceso de aprendizaje, para que
permita al estudiante conocer sus potencialidades y debilidades, cómo mejorar y continuar con
éxito el mismo.
Al inicio del curso se elaborará bosquejo en el cual plasmará los propósitos sobre niveles de
conocimientos y competencias a desenvolver con respecto al desarrollo de la cátedra, el cual se
irá revisando periódicamente por parte del alumno en compañía del docente lo que permitirá
determinar hasta qué punto está logrando los propósitos como parte del cumplimiento de sus
compromisos, llevando al estudiante a que descubra que él es el propio responsable de su
aprendizaje.
7 Recursos Educativos
N
1
Nombre
Textos y revistas
2
Plataforma E-learning
3
Sala de Computadores
4
Software
Justificación
Para el estudio de conceptos y ejemplos y realización de
ejercicios competentes
Utilización del E-learning como complemento a las clases
presénciales
Para el desarrollo practico de los componentes de la
asignatura
Para el desarrollo e implementación
de las distintas
Página 4 de 6
Vicerrectoría de Docencia
Microdiseño
N
5
Nombre
Conexión a Internet
Justificación
soluciones propuestas durante las temáticas
Estudio de temáticas a través de Objetos virtuales de
aprendizaje de otras Universidades
8 Referencias Bibliográficas
8.1
Libros y materiales impresos disponibles en la Biblioteca y Centros de Documentación de la Universidad
Cairo, Oswaldo. Metodología de la programación: algoritmos, diagramas de flujo y programas.
Alfaomega, 2003.
[2] Bowman, Charles F. Algoritmos y estructuras de datos: aproximación en C. Oxford University
Press, 1999.
[3] Fernández, Oliver, Sánchez. Algoritmos: problemas resueltos y comentados, Paraninfo, 1992.
[4] Departamento de Informática y automática. Universidad Nacional de Educación a Distancia.
Estructuras de datos y algoritmos. Prentice Hall. 2001.
[5] Florez R., Roberto. Algoritmos y estructuras de datos.
[6] Flórez R., Roberto. Algoritmos, estructura de datos y programación orientada a objetos. Ecoe,
2005.
[7] Joyanes Aguilar, Luis. Fundamentos de programación: algoritmos, estructuras de datos y objetos.
McGraw Hill, 2008.
[8] Joyanes, luis. Fernández, Matilde. C: manual de programación. McGraw Hill, 2002.
[9] Kernighan, B. , Ritchie, D. El lenguaje de programación C. McGRaw-Hill, 1986.
[10] López , Javier. Introducción a computadores. IGAC, 1991.
[11] Deitel, H. Deitel, P. Cómo programar en C/C++. Pearson Educación, 1995.
[12] Deitel, H. Deitel, P. Cómo programar en C++. Pearson Educación, 2003.
[13] Stroustrup, Bjarne. El lenguaje de programación C++. Adisson Wesley, 2002.
[14] Farrel, Joyce. Iniciación a la programación: lógica y diseño. Paraninfo, 2000.
[15] Gottfried, Byron. Programación en C. McGraw Hill, 1997
[16] Correa Uribe, Guillermo. Desarrollo de algoritmos y sus aplicaciones en Basic, Pascal, Cobol y C
con su respectivo pseudocódico. Mac-GrawHill, 1997.
[17] Sedgewick, Robert. Algoritmos en C++, Prentice Hall, 1995.
[18] Caro, Silvina. Lógica de programación y algoritmos: libro guía. Uniboyaca, 2003.
[19] Rodríguez,C., Llana, L., Pareja C., Martínez, U., Raquel, P. Ejercicios de programación creativos
y recreativos en C++. Prentice Hall, 2002.
[20] Farrell, Joyce. Introducción a la programación: lógica y diseño. Thomson Learning, 2000
[21] Tucker, A. Noonan, R. Lenguajes de programación: principios y paradigmas. McGraw Hill, 2003.
[22] Wirth, Niklaus. Algoritmos y estructuras de datos. Prentice-Hall Hispanoamericana, 1987.
[1]
[23] Aho, Hopcroft, Ullman. Estructuras de datos y algoritmos. Wilmington, Deveware, Estados Unidos: Addison
Wiley Iberoamaericana, 1988.
[24] Joyanes Aguilar, Luis. Fundamentos de programación: Algoritmos y estructura de datos. McGraw-Hill
Interamericana, 1996.
[25] Deitel, H. Deitel, P. C++ cómo programar. Pearson Educación, 1999.
[26] Kelley, Pohl Ira. Lenguaje C: Introducción a la programación. Addison-Wesley Iberoamericana, 1987.
[27] Baase, Sara. Gelder Allen. Algoritmos computacionales: Introducción al análisis y diseño. Pearson, 2002.
8.2
Libros y materiales digitales disponibles en la Biblioteca y Centros de Documentación de la Universidad
[28]
8.3
[29]
[30]
[31]
Documentos y Sitios Web de acceso abierto a través de Internet
Pagina de Unicordoba con Objetos de aprendizaje http://www.aves.edu.co/ovaunicor
http://www.elprisma.com/apuntes
http://www.algoritmia.net
Página 5 de 6
Vicerrectoría de Docencia
Microdiseño
8.1
Libros y materiales impresos disponibles en la Biblioteca y Centros de Documentación de la Universidad
[32]
http://www.umsanet.edu.bo/programacion
8.4
Otros Libros, Materiales y Documentos Digitales
[33]
Página 6 de 6