Encabezado Facultad de Ciencias
Presentación

Ciencias de la Computación (plan 2013) 2024-1

Primer Semestre, Introducción a Ciencias de la Computación

Grupo 7028, 53 lugares. 53 alumnos.
Profesor Canek Peláez Valdés lu mi 13 a 14:30 O134
Ayudante Emiliano Galeana Araujo ma ju 12 a 13 O134
Ayudante Gerardo Emiliano Figueroa Sandoval ma ju 12 a 13
Ayud. Lab. David Armando Silva de Paz ma ju 10 a 12 Laboratorio de Ciencias de la Computación 2
Ayud. Lab. Miriam Torres Bucio ma ju 10 a 12 Laboratorio de Ciencias de la Computación 3
 

Temario

  1. Introducción al curso
    1. Breve historia de las Ciencias de la Computación
    2. Evolución de los lenguajes de programación
    3. Lenguaje de máquina y ejecución de programas
  2. Representación de datos en la computadora
    1. Bases numéricas
    2. Complemento a 2
    3. Punto flotante
  3. Introducción a orientación a objetos con Java
    1. Objetos
    2. Comportamiento y propiedades
    3. Clases, métodos y variables de clase
    4. Encapsolamiento de datos
  4. Estructuras de control y listas
    1. Listas
    2. Estructuras de control
    3. Algoritmos iterativos
  5. Recursión
    1. La pila de ejecución
    2. Algoritmos recursivos
    3. Torres de Hanoi
  6. Herencia
    1. Clases y métodos abstractos
    2. Interfaces
    3. Comportamiento heredado
  7. Entrada y Salida, excepciones
    1. Entrada
    2. Salida
    3. Excepciones
  8. Enumeraciones
    1. Constantes y números mágicos
    2. Enumeraciones enteras
    3. Enumeraciones en otros lenguajes de programación
    4. Enumeraciones en Java
  9. Genéricos
    1. Genéricos en Java
    2. Implementación de genéricos en Java
    3. Clases, interfaces y métodos genéricos
  10. Iteradores
    1. Iteradores en Java
    2. Comportamiento de iteradores
    3. Recorriendo iterables
  11. Lambdas
    1. Lambdas y funciones anónimas
    2. Clases internas anónimas
    3. Implementación en Java
  12. Arreglos, ordenamientos y búsquedas
    1. Arreglos en Java
    2. Ordenamientos en arreglos y listas
    3. Búsquedas en arreglos y listas
  13. Interfaces gráficas
    1. Java FX
    2. Patrón Modelo-Vista-Controlador
    3. Lambdas en interfaces gráficas
  14. Programación en red
    1. Enchufes
    2. Modelo servidor/cliente
    3. Entrada y salida con enchufes
  15. Programación concurrente
    1. Hilos de ejecución
    2. Los filósofos chinos
    3. Sincronización de hilos de ejecución

Modo presencial

El curso será en modalidad presencial.


Evaluación

El curso se evaluará de la siguiente manera:

Exámenes parciales: 30%
Exámenes semanales: 20%
Proyectos: 30%
Prácticas: 20%

Evaluación teórica

Habrá tres exámenes parciales, cada uno de los cuales cubrirá aproximadamente la tercera parte del material visto en clase. En los examenes parciales no se les solicitará escribir código, pero sí que lean y analicen código.

Los exámenes semanales son exámenes cortos (diez minutos) que se llevarán a cabo los jueves, y donde se harán preguntas referentes a los conceptos vistos durante la semana. Una vez que todos los alumnos hayan entregado el examen, el profesor explicará las respuestas correctas a las preguntas del mismo.

No hay exámenes de reposición ni examen final.

Evaluación práctica

Habrá tres proyectos, para realizarse de forma individual, y consistirán en implementar la solución a un problema específico, utilizando los conceptos y herramientas vistos durante el curso.

Las prácticas consistirán en implementar, en su totalidad o en parte, las clases y métodos correspondientes que se les dejen. Las prácticas también deberán realizarse de forma individual.

La calificación de las prácticas depende de las pruebas unitarias incluidas en cada una de ellas. Si la práctica que el alumno entregue pasa todas las pruebas unitarias la calificación será, en principio, 10. Si un estudiante consigue escribir código demostrablemente incorrecto que pase todas las pruebas unitarias de una práctica, y le avisa al profesor antes de la fecha de entrega, el estudiante obtendrá un punto extra en esa práctica.

Para alcanzar al menos el 5 de calificación, la práctica debe compilar correctamente y sin advertencias. No está permitido bajo ninguna circunstancia utilizar clases del paquete java.util (excepto excepciones y enumeraciones), ni agregar variables de clase (ni públicas ni privadas) a ninguna clase vista durante el curso. Tampoco está permitido agregar métodos públicos; pero métodos privados están permitidos, y de hecho se les sugiere que los utilicen.

Si el ayudante o profesor detectan que han copiado en alguna práctica o proyecto, la calificación de la misma se dividirá entre el número de estudiantes que hayan copiado. Si el profesor detecta que un proyecto fue bajado de internet, la calificación será cero.

Las prácticas y proyectos estarán disponibles en el repositorio del curso. Ahí también encontrarán las instrucciones para entregarlos.

La fecha límite de entrega de prácticas y proyectos es inamovible.


Renuncias y NPs

Si un estudiante requiere NP como calificación, debe solicitar su renuncia al curso a más tardar a la octava semana del mismo. De no hacerlo, el estudiante tendrá en actas la calificación correspondiente a lo que haya entregado durante el curso, siendo 5 en el caso de no alcanzar una calificación aprobatoria. La solicitud de renuncia se puede realizar vía correo electrónico.

No se guardan calificaciones para próximos semestres ni para exámenes extraordinarios. Mucho menos se “pasan” o “reciben” calificaciones a o de otros profesores.

 


Hecho en México, todos los derechos reservados 2011-2016. Esta página puede ser reproducida con fines no lucrativos, siempre y cuando no se mutile, se cite la fuente completa y su dirección electrónica. De otra forma requiere permiso previo por escrito de la Institución.
Sitio web administrado por la Coordinación de los Servicios de Cómputo de la Facultad de Ciencias. ¿Dudas?, ¿comentarios?. Escribenos. Aviso de privacidad.