Tema 12: Programas interactivos
|
|
|
- José Manuel de la Cruz Rojas
- hace 9 años
- Vistas:
Transcripción
1 Tema 12: Programas interactivos Programación declarativa ( ) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla Tema 12: Programas interactivos 1. Programas interactivos 2. El tipo de las acciones de entrada/salida 3. Acciones básicas 4. Secuenciación 5. Primitivas derivadas 6. Juego de adivinación interactivo Calculadora aritmética 2 / 38
2 Programas interactivos Tema 12: Programas interactivos 1. Programas interactivos 2. El tipo de las acciones de entrada/salida 3. Acciones básicas 4. Secuenciación 5. Primitivas derivadas 6. 3 / 38 Programas interactivos Programas interactivos Los programas por lote no interactúan con los usuarios durante su ejecución. Los programas interactivos durante su ejecución pueden leer datos del teclado y escribir resultados en la pantalla. Problema: Los programas interactivos tienen efectos laterales. Los programa Haskell no tiene efectos laterales. 4 / 38
3 Programas interactivos Ejemplo de programa interactivo Especificación: El programa pide una cadena y dice el número de caracteres que tiene. Ejemplo de sesión: -- *Main> longitudcadena -- Escribe una cadena: "Hoy es lunes" -- La cadena tiene 14 caracteres Programa: longitudcadena :: IO () longitudcadena = do putstr "Escribe una cadena: " xs <- getline putstr "La cadena tiene " putstr (show (length xs)) putstrln " caracteres" 5 / 38 El tipo de las acciones de entrada/salida Tema 12: Programas interactivos 1. Programas interactivos 2. El tipo de las acciones de entrada/salida 3. Acciones básicas 4. Secuenciación 5. Primitivas derivadas 6. 6 / 38
4 El tipo de las acciones de entrada/salida El tipo de las acciones de entrada/salida En Haskell se pueden escribir programas interactivos usando tipos que distingan las expresiones puras de las acciones impuras que tienen efectos laterales. IO a es el tipo de las acciones que devuelven un valor del tipo a. Ejemplos: IO Char es el tipo de las acciones que devuelven un carácter. IO () es el tipo de las acciones que no devuelven ningún valor. 7 / 38 Acciones básicas Tema 12: Programas interactivos 1. Programas interactivos 2. El tipo de las acciones de entrada/salida 3. Acciones básicas 4. Secuenciación 5. Primitivas derivadas 6. 8 / 38
5 Acciones básicas Acciones básicas getchar :: IO Char La acción getchar lee un carácter del teclado, lo muestra en la pantalla y lo devuelve como valor. putchar :: c -> IO () La acción putchar c escribe el carácter c en la pantalla y no devuelve ningún valor. return a -> IO a La acción return c devuelve el valor c sin ninguna interacción. Ejemplo: *Main> putchar 'b' b*main> it () 9 / 38 Secuenciación Tema 12: Programas interactivos 1. Programas interactivos 2. El tipo de las acciones de entrada/salida 3. Acciones básicas 4. Secuenciación 5. Primitivas derivadas / 38
6 Secuenciación Secuenciación Una sucesión de acciones puede combinarse en una acción compuesta mediante expresiones do. Ejemplo: ejsecuenciacion :: IO (Char,Char) ejsecuenciacion = do x <- getchar getchar y <- getchar return (x,y) Lee dos caracteres y devuelve el par formado por ellos. Por ejemplo, *Main> ejsecuenciacion b f ('b','f') 11 / 38 Primitivas derivadas Tema 12: Programas interactivos 1. Programas interactivos 2. El tipo de las acciones de entrada/salida 3. Acciones básicas 4. Secuenciación 5. Primitivas derivadas / 38
7 Primitivas derivadas Primitivas derivadas de lectura Lectura de cadenas del teclado: Prelude getline :: IO String getline = do x <- getchar if x == '\n' then return [] else do xs <- getline return (x:xs) 13 / 38 Primitivas derivadas Primitivas derivadas de escritura Escritura de cadenas en la pantalla: Prelude putstr :: String -> IO () putstr [] = return () putstr (x:xs) = do putchar x putstr xs Escritura de cadenas en la pantalla y salto de línea: Prelude putstrln :: String -> IO () putstrln xs = do putstr xs putchar '\n' 14 / 38
8 Primitivas derivadas Primitivas derivadas: lista de acciones Ejecución de una lista de acciones: Prelude sequence_ :: [IO a] -> IO () sequence_ [] = return () sequence_ (a:as) = do a Por ejemplo, sequence_ as *Main> sequence_ [putstrln "uno", putstrln "dos"] uno dos *Main> it () 15 / 38 Primitivas derivadas Ejemplo de programa con primitivas derivadas Especificación: El programa pide una cadena y dice el número de caracteres que tiene. Ejemplo de sesión: -- *Main> longitudcadena -- Escribe una cadena: "Hoy es lunes" -- La cadena tiene 14 caracteres Programa: longitudcadena :: IO () longitudcadena = do putstr "Escribe una cadena: " xs <- getline putstr "La cadena tiene " putstr (show (length xs)) putstrln " caracteres" 16 / 38
9 Tema 12: Programas interactivos 1. Programas interactivos 2. El tipo de las acciones de entrada/salida 3. Acciones básicas 4. Secuenciación 5. Primitivas derivadas 6. Juego de adivinación interactivo Calculadora aritmética Juego de adivinación interactivo 17 / 38 Juego de adivinación interactivo Descripción: El programa le pide al jugador humano que piense un número entre 1 y 100 y trata de adivinar el número que ha pensado planteándole conjeturas a las que el jugador humano responde con mayor, menor o exacto según que el número pensado sea mayor, menor o igual que el número conjeturado por la máquina. Ejemplo de sesión: Main> juego Piensa un numero entre el 1 y el 100. Es 50? [mayor/menor/exacto] mayor Es 75? [mayor/menor/exacto] menor Es 62? [mayor/menor/exacto] mayor Es 68? [mayor/menor/exacto] exacto Fin del juego 18 / 38
10 Juego de adivinación interactivo Juego interactivo Programa: juego :: IO () juego = do putstrln "Piensa un numero entre el 1 y el 100." adivina putstrln "Fin del juego" adivina :: Int -> Int -> IO () adivina a b = do putstr ("Es " ++ show conjetura ++ "? [mayor/menor/exacto] ") s <- getline case s of "mayor" -> adivina (conjetura+1) b "menor" -> adivina a (conjetura-1) "exacto" -> return () _ -> adivina a b where conjetura = (a+b) `div` 2 19 / 38 Calculadora aritmética Acciones auxiliares Escritura de caracteres sin eco: getch :: IO Char getch = do hsetecho stdin False c <- getchar hsetecho stdin True return c Limpieza de la pantalla: limpiapantalla:: IO () limpiapantalla= putstr "\ESC[2J" 20 / 38
11 Calculadora aritmética Acciones auxiliares Escritura en una posición: type Pos = (Int,Int) ira :: Pos -> IO () ira (x,y) = putstr ("\ESC[" ++ show y ++ ";" ++ show x ++ "H") escribeen :: Pos -> String -> IO () escribeen p xs = do ira p putstr xs 21 / 38 Calculadora aritmética Calculadora calculadora :: IO () calculadora = do limpiapantalla escribecalculadora limpiar escribecalculadora :: IO () escribecalculadora = do limpiapantalla sequence_ [escribeen (1,y) xs (y,xs) <- zip [1..13] imagencalculadora] putstrln "" 22 / 38
12 Calculadora aritmética Calculadora imagencalculadora :: [String] imagencalculadora = [" ", " ", " ", " q c d = ", " ", " ", " ", " ", " ", " * ", " ", " 0 ( ) / ", " "] Los primeros cuatro botones permiten escribir las órdenes: q para salir ( quit ), c para limpiar la agenda ( clear ), d para borrar un carácter ( delete ) y = para evaluar una expresión. Los restantes botones permiten escribir las expresiones. 23 / 38 Calculadora aritmética Calculadora limpiar :: IO () limpiar = calc "" calc :: String -> IO () calc xs = do escribeenpantalla xs c <- getch if elem c botones then procesa c xs else do calc xs escribeenpantalla xs = do escribeen (3,2) " " escribeen (3,2) (reverse (take 13 (reverse xs))) 24 / 38
13 Calculadora aritmética Calculadora botones :: String botones = standard ++ extra where standard = "qcd= *0()/" extra = "QCD \ESC\BS\DEL\n" procesa :: Char -> String -> IO () procesa c xs elem c "qq\esc" = salir elem c "dd\bs\del" = borrar xs elem c "=\n" = evaluar xs elem c "cc" = limpiar otherwise = agregar c xs 25 / 38 Calculadora aritmética Calculadora salir :: IO () salir = ira (1,14) borrar :: String -> IO () borrar "" = calc "" borrar xs = calc (init xs) evaluar :: String -> IO () evaluar xs = case analiza expr xs of [(n,"")] -> calc (show n) _ -> do calc xs agregar :: Char -> String -> IO () agregar c xs = calc (xs ++ [c]) 26 / 38
14 Descripción del juego de la vida El tablero del juego de la vida es una malla formada por cuadrados ( células ) que se pliega en todas las direcciones. Cada célula tiene 8 células vecinas, que son las que están próximas a ella, incluso en las diagonales. Las células tienen dos estados: están vivas o muertas. El estado del tablero evoluciona a lo largo de unidades de tiempo discretas. Las transiciones dependen del número de células vecinas vivas: Una célula muerta con exactamente 3 células vecinas vivas nace (al turno siguiente estará viva). Una célula viva con 2 ó 3 células vecinas vivas sigue viva, en otro caso muere. 27 / 38 El tablero del juego de la vida Tablero: type Tablero = [Pos] Dimensiones: ancho :: Int ancho = 5 alto :: Int alto = 5 28 / 38
15 Ejemplo de tablero: ejtablero :: Tablero ejtablero = [(2,3),(3,4),(4,2),(4,3),(4,4)] Representación del tablero: O 3 O O 4 OO 29 / 38 (vida n t) simula el juego de la vida a partir del tablero t con un tiempo entre generaciones proporcional a n. Por ejemplo, vida ejtablero vida :: Int -> Tablero -> IO () vida n t = do limpiapantalla escribetablero t espera n vida n (siguientegeneracion t) Escritura del tablero: escribetablero :: Tablero -> IO () escribetablero t = sequence_ [escribeen p "O" p <- t] 30 / 38
16 Espera entre generaciones: espera :: Int -> IO () espera n = sequence_ [return () _ <- [1..n]] siguientegeneracion t) es el tablero de la siguiente generación al tablero t. Por ejemplo, *Main> siguientegeneracion ejtablero [(4,3),(3,4),(4,4),(3,2),(5,3)] siguientegeneracion :: Tablero -> Tablero siguientegeneracion t = supervivientes t ++ nacimientos t 31 / 38 (supervivientes t) es la listas de posiciones de t que sobreviven; i.e. posiciones con 2 ó 3 vecinos vivos. Por ejemplo, supervivientes ejtablero [(4,3),(3,4),(4,4)] supervivientes :: Tablero -> [Pos] supervivientes t = [p p <- t, elem (nvecinosvivos t p) [2,3]] (nvecinosvivos t c) es el número de vecinos vivos de la célula c en el tablero t. Por ejemplo, nvecinosvivos ejtablero (3,3) 5 nvecinosvivos ejtablero (3,4) 3 nvecinosvivos :: Tablero -> Pos -> Int nvecinosvivos t = length. filter (tienevida t). vecinos 32 / 38
17 (vecinos p) es la lista de los vecinos de la célula en la posición p. Por ejemplo, vecinos (2,3) [(1,2),(2,2),(3,2),(1,3),(3,3),(1,4),(2,4),(3,4)] vecinos (1,2) [(5,1),(1,1),(2,1),(5,2),(2,2),(5,3),(1,3),(2,3)] vecinos (5,2) [(4,1),(5,1),(1,1),(4,2),(1,2),(4,3),(5,3),(1,3)] vecinos (2,1) [(1,5),(2,5),(3,5),(1,1),(3,1),(1,2),(2,2),(3,2)] vecinos (2,5) [(1,4),(2,4),(3,4),(1,5),(3,5),(1,1),(2,1),(3,1)] vecinos (1,1) [(5,5),(1,5),(2,5),(5,1),(2,1),(5,2),(1,2),(2,2)] vecinos (5,5) [(4,4),(5,4),(1,4),(4,5),(1,5),(4,1),(5,1),(1,1)] vecinos :: Pos -> [Pos] vecinos (x,y) = map modular [(x-1,y-1), (x,y-1), (x+1,y-1), (x-1,y), (x+1,y), (x-1,y+1), (x,y+1), (x+1,y+1)] 33 / 38 (modular p) es la posición correspondiente a p en el tablero considerando los plegados. Por ejemplo, modular (6,3) (1,3) modular (0,3) (5,3) modular (3,6) (3,1) modular (3,0) (3,5) modular :: Pos -> Pos modular (x,y) = (((x-1) `mod` ancho) + 1, ((y-1) `mod` alto / 38
18 (tienevida t p) se verifica si la posición p del tablero t tiene vida. Por ejemplo, tienevida ejtablero (1,1) False tienevida ejtablero (2,3) True tienevida :: Tablero -> Pos -> Bool tienevida t p = elem p t (notienevida t p) se verifica si la posición p del tablero t no tiene vida. Por ejemplo, notienevida ejtablero (1,1) True notienevida ejtablero (2,3) False notienevida :: Tablero -> Pos -> Bool notienevida t p = not (tienevida t p) 35 / 38 (nacimientos t) es la lista de los nacimientos de tablero t; i.e. las posiciones sin vida con 3 vecinos vivos. Por ejemplo, nacimientos ejtablero [(3,2),(5,3)] nacimientos' :: Tablero -> [Pos] nacimientos' t = [(x,y) x <- [1..ancho], y <- [1..alto], notienevida t (x,y), nvecinosvivos t (x,y) == 3] 36 / 38
19 Definición más eficiente de nacimientos nacimientos :: Tablero -> [Pos] nacimientos t = [p p <- nub (concat (map vecinos t)), notienevida t p, nvecinosvivos t p == 3] donde (nub xs) es la lista obtenida eliminando las repeticiones de xs. Por ejemplo, nub [2,3,2,5] [2,3,5] Bibliografía 37 / 38 Bibliografía 1. H. Daumé III. Yet Another Haskell Tutorial Cap. 5: Basic Input/Output. 2. G. Hutton. Programming in Haskell. Cambridge University Press, Cap. 9: Interactive programs. 3. B. O Sullivan, J. Goerzen y D. Stewart. Real World Haskell. O Reilly, Cap. 7: I/O. 4. B.C. Ruiz, F. Gutiérrez, P. Guerrero y J.E. Gallardo. Razonando con Haskell. Thompson, Cap. 7: Entrada y salida. 5. S. Thompson. Haskell: The Craft of Functional Programming, Second Edition. Addison-Wesley, Cap. 18: Programming with actions. 38 / 38
Tema 12: Programas interactivos
Tema 12: Programas interactivos Programación declarativa (2010 11) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla Tema 12:
Tema 13: Programas interactivos
Tema 13: Programas interactivos Informática (2015 16) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla 2 / 38 Tema 13: Programas
Tema 6: Funciones recursivas
Tema 6: Funciones recursivas Programación declarativa (2009 10) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla Tema 6: Funciones
Tema 4: Definición de funciones
Programación declarativa (2009 10) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla Constantes como patrones Variables como
Tema 3: Tipos y clases
Tema 3: Tipos y clases Programación declarativa (2009 10) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla Tema 3: Tipos y clases
Tema 3: Tipos y clases
Tema 3: Tipos y clases Programación declarativa (2010 11) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla Tema 3: Tipos y clases
Tema 4: Definición de funciones
Tema 4: Definición de funciones Informática (2010 11) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla 2 / 30 Tema 4: Definición
Tema 3: Tipos y clases
Tema 3: Tipos y clases Informática (2016 17) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla 2 / 32 IM Tema 3: Tipos y clases
Tema 5: Definiciones de listas por comprensión
Tema 5: Definiciones de listas por comprensión Programación declarativa (2009 10) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla
Tema 5: Definiciones de listas por comprensión
Tema 5: Definiciones de listas por comprensión Programación declarativa (2009 10) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla
Tema 2: Introducción a la programación con Haskell
Tema 2: Introducción a la programación con Haskell Programación declarativa (2009 10) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad
Tema 9: Declaraciones de tipos y clases
Tema 9: Declaraciones de tipos y clases Programación declarativa (2009 10) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla
Tema 13: Aplicaciones de programación funcional
Tema 13: Aplicaciones de programación funcional Programación declarativa (2010 11) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de
Tema 2: Introducción a la programación con Haskell
Tema 2: Introducción a la programación con Haskell Informática (2015 16) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla 2
Introducción a Haskell. Cecilia Manzino
Paradigmas de programación Un paradigma de programación representa un estilo particular o filosofía para la construcción del software. Los más comunes dan lugar a los siguientes tipos de programación:
Programación Declarativa Haskell Informática Sistemas Curso Pepe Gallardo Universidad de Málaga. Tema 8. Listas
Programación Declarativa Haskell Informática Sistemas Curso 2003-2004 Pepe Gallardo Universidad de Málaga Tema 8. Listas 8.1 Secuencias aritméticas 8.2 Algunas funciones predefinidas 8.3 Listas por comprensión
Programación Funcional en Haskell
Programación Funcional en Haskell Paradigmas de Lenguajes de Programación 1 cuatrimestre 2006 1. Expresiones, valores y tipos Un programa en lenguaje funcional consiste en definir expresiones que computan
Tema 21: Algoritmos de exploración de grafos
Tema 21: Algoritmos de exploración de grafos Informática (2009 10) José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla Tema 21:
Programación Funcional
Alberto Pardo Marcos Viera Instituto de Computación, Facultad de Ingeniería Universidad de la República, Uruguay Operaciones sobre listas Listas El tipo de las listas es uno de los más usados en PF Su
Informática Haskell Matemáticas Curso Pepe Gallardo Universidad de Málaga. Tema 8. Listas
Informática Haskell Matemáticas Curso 2004-2005 Pepe Gallardo Universidad de Málaga Tema 8. Listas 8.1 Secuencias aritméticas 8.2 Algunas funciones predefinidas 8.3 Listas por comprensión Ejemplo: QuickSort
Tema 3. Patrones y Definiciones de Funciones
Programación Declarativa Haskell Informática Sistemas Curso 2003-2004 Pepe Gallardo Universidad de Málaga Tema 3. Patrones y Definiciones de Funciones 3.1 Comparación de Patrones Patrones constantes Patrones
Introducción. Haskell
Introducción Haskell 1 Valores, Tipos, Expresiones Los valores son entidades abstractas que podemos considerar como la respuesta a un cálculo 5-1 8 Cada valor tiene asociado un tipo ( :: )
Tipos de datos algebraicos
Tipos de datos algebraicos Taller de Álgebra I Segundo cuatrimestre de 2013 Programación funcional Recordemos que un tipo de datos es un conjunto dotado con una serie de operaciones sobre los elementos
data Tree a = Tip Node a (Tree a) (Tree a) deriving Show
Preguntas seleccionadas de pruebas de evaluación Pregunta 1 Dadas las siguientes definiciones: data Tree a = Tip Node a (Tree a) (Tree a) deriving Show cambiar :: [Int] -> Tree [Int] -> Tree [Int] cambiar
Tipos algebraicos y abstractos. Algoritmos y Estructuras de Datos I. Tipos algebraicos
Algoritmos y Estructuras de Datos I 1 cuatrimestre de 009 Departamento de Computación - FCEyN - UBA Programación funcional - clase Tipos algebraicos Tipos algebraicos y abstractos ya vimos los tipos básicos
Introducción a la Programación Genérica
Introducción a la Programación Genérica Alberto Pardo Instituto de Computación Facultad de Ingeniería Universidad de la República http://www.fing.edu.uy/inco/cursos/proggen Objetivo del curso Introducción
Programación Funcional Haskell Clase 21
Programación Funcional Haskell Clase 21 José Raymundo Marcial Romero [email protected] BUAP c José Raymundo Marcial Romero. Clase Número 21 p.1/12 Temas de la clase Clase Anterior En Haskell cada expresión
Listas y Recursión. Taller de Álgebra I. Primer Cuatrimestre de 2015
Listas y Recursión Taller de Álgebra I Primer Cuatrimestre de 2015 Un nuevo tipo: Listas Tipo Lista Las listas pueden contener elementos de cualquier tipo (incluso listas) [1] :: [Integer] [1, 2] :: [Integer]
Para entender la recursividad primero tenemos que entender la recursividad
Para entender la recursividad primero tenemos que entender la recursividad Funcional Clase 1 Matias Reparaz, Agustín Nieto Departamento de Computación, FCEyN,Universidad de Buenos Aires. 20 de Septiembre
Tema 2. Tipos predefinidos
Programación Declarativa Haskell Informática Sistemas Curso 2003-2004 Pepe Gallardo Universidad de Málaga Tema 2. Tipos predefinidos 2.1 Tipos simples predefinidos El tipo Bool El tipo Int El tipo Integer
Programación Funcional Haskell Clase 19
Programación Funcional Haskell Clase 19 José Raymundo Marcial Romero [email protected] BUAP c José Raymundo Marcial Romero. Clase Número 19 p.1/23 Temas de la clase Lenguajes Funcionales Haskell y
Lenguaje de programación C. Introducción
Lenguaje de programación C Introducción 1 Elementos del lenguaje C Colección de funciones Estas funciones contienen declaraciones, sentencias, expresiones y otros elementos que en conjunto indican a la
Cátedra I Informática Autor I Carlos Bartó
FCEFyN Departamento de Computación Informática Examen - 07-07-2008 Apellido y Nombres: Matrícula: Carrera: PROBLEMAS: 1) Especifique en el lenguaje C++ una función denominada calc_fecha() que tenga como
EJERCICIOS DE LENGUAJES Y PARADIGMAS DE PROGRAMACIÓN (CUESTIONES DE EXAMEN) PROGRAMACIÓN FUNCIONAL
EJERCICIOS DE LENGUAJES Y PARADIGMAS DE PROGRAMACIÓN (CUESTIONES DE EXAMEN) PROGRAMACIÓN FUNCIONAL María Alpuente y María José Ramírez 1 LENGUAJES Y PARADIGMAS: INTRODUCCIÓN 1. Indica cuál de las siguientes
ALPII Práctica 3. Bernardo García Fuentes
ALPII Práctica 3 Bernardo García Fuentes 1 Ej. 1................................................................................................. modulus :: [Float] -> Float modulus = sqrt.sum.map square
Codificación en C. Como pasar de Pseudocódigo a C (con pequeños trucos de C++)
Codificación en C Como pasar de Pseudocódigo a C (con pequeños trucos de C++) Plantilla Librerias Constantes Algoritmo #include #include #define PI 3.1416 int main(void){ /*Variables*/
Introducción a Haskell. El lenguaje Haskell
Capítulo 2. Introducción a Haskell 9 Introducción a Haskell Un ejemplo de fichero Haskell El lenguaje Haskell Haskell es un lenguaje funcional puro, no estricto y fuertemente tipificado. Puro = transparencia
Tema 7. El sistema de clases
Programación Declarativa Haskell Informática Sistemas Curso 2003-2004 Pepe Gallardo Universidad de Málaga Tema 7. El sistema de clases 7.1 Funciones Sobrecargadas Clases e Instancias 7.2 Algunas Clases
FUNDAMENTOS DE PROGRAMACIÓN. SEPTIEMBRE 2007.
Dpto. Ingeniería de Sistemas Telemáticos Universidad Politécnica de Madrid ETSI Telecomunicación, Ciudad Universitaria, 28040 Madrid FUNDAMENTOS DE PROGRAMACIÓN. SEPTIEMBRE 2007. Normas de examen: Con
Tipos de Datos en C. Palabras reservadas en C
Tipos de Datos en C Tipo Tamaño de bits Rango char 8-128 a 127 unsigned char 8 0 a 255 signed char 8-128 a 127 int 16 32768 a 32767 unsigned int 16 0 a 65535 signed int 16 Igual que int short int 16 Igual
Programación lógica ( )
1 / 48 Programación lógica (2008 09) Tema 4: Resolución de problemas de espacios de estados José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad
Tema: Autómatas de Estado Finitos
Compiladores. Guía 2 1 Facultad: Ingeniería Escuela: Computación Asignatura: Compiladores Tema: Autómatas de Estado Finitos Contenido En esta guía se aborda la aplicación de los autómatas en el campo de
Contenido. 1. Introducción a la programación La secuenciación La selección...55
Contenido - IX Contenido 1. Introducción a la programación...1 1.1 Conceptos generales...3 La computadora... 3 El programa... 6 Estructuras de datos... 6 Operaciones primitivas elementales... 7 Estructuras
Reales. Caracteres. Cadenas de Caracteres (String)
Conceptos preliminares para la programación Algoritmo: Conjunto de pasos lógicos, secuenciales y finitos para dar solución a un problema general. Dato: Es una característica de un objeto o entidad, que
Laboratorio de Arquitectura de Redes. Entrada y salida estándar
Laboratorio de Arquitectura de Redes Entrada y salida estándar Entrada y salida estándar Entradas y salidas Salida con formato: printf() Entrada de datos con formato: scanf() El buffer de teclado Entrada
PILAS. Prof. Ing. M.Sc. Fulbia Torres
S ESTRUCTURAS DE DATOS 2006 Prof. UNIDAD II ESTRUCTURAS DE DATOS PILAS Definición. Operaciones. Implementación secuencial. Aplicaciones. Ejemplos. Ejercicios. DEFINICIÓN Una PILA (o stack) es una estructura
Apunte Laboratorio ALPI - El lenguaje de programación Pascal
Apunte Laboratorio ALPI - El lenguaje de programación Pascal 1 2 ÍNDICE GENERAL Índice 1. Estructura de un Programa en Pascal 3 2. Sintaxis de Pascal 4 2.1. Uso de mayúsculas.....................................
Ejercicios Tema 6. Funciones
Ejercicios Tema 6. Funciones 1. Programa que calcule el cuadrado de todos los números comprendidos entre dos dados. Usar una función a la que se le pasa como parámetro un valor y retorna su cuadrado. 2.
Estatutos de Control C# Estatutos de Decisión (Selección)
SELECCIÓN Estatutos de Control C# Estatutos de Decisión (Selección) IF Condición THEN Estatuto1 ELSE Estatuto2 Estatuto1 Statement Condición... Antes de ver esta presentación: Lee el Capítulo correspondiente
Práctica N o 1 - Programación Funcional
Práctica N o 1 - Programación Funcional Para resolver esta práctica, recomendamos usar el Hugs 98, de distribución gratuita, que puede bajarse de http://www.haskell.org/hugs/. Ejercicio 1 Dado el siguiente
Programación Declarativa Curso
Programación Declarativa Curso 2004-2005 Ingeniería Técnica en Informática de Gestión Departamento de Lenguajes y Ciencias de la Computación Universidad de Málaga Programación Declarativa 1 Profesorado
Estructuras de Repetición (Hacer-Mientras)
Estructuras de Repetición (Hacer-Mientras) Material Original: Prof. Flor Narciso Modificaciones: Prof. Andrés Arcia Departamento de Computación Escuela de Ingeniería de Sistemas Facultad de Ingeniería
Introducción al Lenguaje de Programación Ada
Instrumentación de Tiempo Real Introducción al Lenguaje de Programación Ada Mario Aldea Rivas Departamento de Electrónica y Computadores Universidad de Cantabria GRUPO DE COMPUTADORES Y TIEMPO REAL Mario
INTRODUCCIÓN AL TIPO COMPUESTO CADENA CONTENIDOS
CONTENIDOS 1. Introducción a las cadenas 2. Definición 3. Declaración de cadenas 4. Inicialización de cadenas 5. Escritura y Lectura de datos tipo cadena 6. Funciones de manipulación de cadenas 7. Arrays
Estructuras de Selección, armado de Equipos, y Trabajo #1.
Estructuras de Selección, armado de Equipos, y Trabajo #1. Clase a Distancia Leer sobre estructuras de control de la página 19 de https://droscarbruno.files.wordpress.com/2015/02/ modulo1introduccion20151.pdf
Tema 3: Características de la programación funcional. Sesión 5: El paradigma funcional (1)
Tema 3: Características de la programación funcional Sesión 5: El paradigma funcional (1) Referencias Capítulo 1.1.5 SICP: [[http://mitpress.mit.edu/sicp/full-text/book/book-z- H-10.html#%_sec_1.1.5][The
Programación Declarativa UNIVERSIDAD DE MÁLAGA
Programación Declarativa UNIVERSIDAD DE MÁLAGA (3 o de Ingeniería Técnica en Informática) E.T.S.I. INFORMÁTICA 17 de Febrero de 2005 Alumno: Grupo: Prolog Ejercicio 1 (a)(2 pts.) Realiza el árbol de búsqueda
Contenido. 4. La selección Introducción a la programación Elementos para solucionar problemas en seudocódigo...
7 Contenido Convenciones utilizadas en el texto...10 Registro en la Web de apoyo...11 Prefacio...13 1. Introducción a la programación...19 1.1 Conceptos generales...21 1.2 Evolución de los paradigmas de
Lenguaje de Programación: C++ Estructuras de control:switch
UG C++ Lenguaje de Programación: C++ Estructuras de control: Universidad de Guanajuato Septiembre 2010 Estructuras de selección Aunque la sentencia if de C++ es muy potente, en ocasiones su escritura puede
Objetivos. El alumno conocerá y aplicará el concepto de archivo para el almacenamiento y recuperación de datos persistentes.
Objetivos El alumno conocerá y aplicará el concepto de archivo para el almacenamiento y recuperación de datos persistentes. Al final de esta práctica el alumno podrá: 1. Utilizar las herramientas para
Introducción rápida a la programación (estructurada ) con C++
Introducción rápida a la programación (estructurada ) con C++ A B No A? Si B A Los Bloques pueden ser una línea de código o un modulo (función o subrutina) que pueden estar contenido en otro archivo de
Solución práctico 6 Tipos Abstractos de Datos Lista, Pila y Cola
Objetivos Trabajar sobre el Tipo Abstracto de Datos Lista, reforzando el desacople entre especificación e implementación. Retomar las implementaciones vistas, como ser Listas Doblemente Encadenadas, Listas
EQUIVALENCIAS EN C DE CONSTRUCCIONES SECUENICIALES EN PSEUDOCÓDIGO
EQUIVALENCIAS EN C DE CONSTRUCCIONES SECUENICIALES EN PSEUDOCÓDIGO TIPOS DE DATOS BÁSICOS: Tipo Tipo Tamaño aproximado en bits Rango mínimo Carácter char 8 0 a 55 Entero int 16-3767 a 3767 Real float 3
Programación de Computadores 4 Iteraciones y Decisiones. Prof. Javier Cañas. Universidad Técnica Federico Santa María Departamento de Informática
Programación de Computadores 4 Iteraciones y Decisiones Prof. Javier Cañas Universidad Técnica Federico Santa María Departamento de Informática Contenido 1 Introducción 2 Operadores Relacionales y Lógicos
Introducción a Python. Cecilia Manzino
Características del lenguaje Es un lenguaje de programación multiparadigma, soporta la programación orientada a objetos, imperativa y, en menor medida, funcional. Es un lenguaje multiplataforma, puede
PROGRAMACION ESTRUCTURADA: Tema 1. El lenguaje de programación C
PROGRAMACION ESTRUCTURADA: Tema 1. El lenguaje de programación C Presenta: David Martínez Torres Universidad Tecnológica de la Mixteca Instituto de Computación Oficina No. 37 [email protected] Contenido
Exámenes de Programación funcional con Haskell ( )
Exámenes de Programación funcional con Haskell (2009 2014) José A. Alonso (coord.) y Gonzalo Aranda, Antonia M. Chávez, Andrés Cordón, María J. Hidalgo, Francisco J. Martín Miguel A. Martínez, Ignacio
Programación 1 Tema 3. Información, datos, operaciones y expresiones
Programación 1 Tema 3 Información, datos, operaciones y expresiones Índice Datos y tipos de datos Datos primitivos en C++ Expresiones e instrucción de asignación Datos y tipos de datos Problema información
Capítulo 3. Sentencias condicionales
Capítulo 3. Universidad del País Vasco / Euskal Herriko Unibertsitatea 79 Índice del capítulo 1. Introducción........................................ 81 2. Objetivos...........................................
PROGRAMACIÓN EN JAVA
1. INTRODUCCIÓN A LA PROGRAMACIÓN 1.1. Datos, algoritmos y programas 1.1.1. Definición de algoritmo 1.1.2. Datos 1.1.3. Características de un programa 1.2. Paradigmas de programación 1.2.1. Programación
El sistema de clases de Haskell. Introducción
Capítulo 5. El sistema de clases de Haskell 56 El sistema de clases de Haskell Introducción Función monomórfica: sólo se puede usar para valores de un tipo concreto not :: Bool Bool not True = False not
Guía 2: Listas, recursión e inducción
Introducción a los Algoritmos - 2do cuatrimestre 2014 Guía 2: Listas, recursión e inducción Docentes: Walter Alini, Luciana Benotti En esta guía comenzaremos a trabajar con listas Para familiarizarnos
Lógica y Programación
Lógica y Programación Programación funcional con Haskell Antonia M. Chávez, Carmen Graciani, Agustín Riscos Dpto. Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Programación
Shell Script Sistemas Operativos III - ITS EMT - CETP
Shell Script SHELL tiene dos formas distintas de ejecutar comandos : Archivos binarios Programas compilados y de los cuales existe un ejecutable archivos.exe ó.com en MS-DOS Archivos de texto Contienen
Descripción de un Programa
Unidad 2 Descripción de un Programa 1 El Lenguaje C (1) El lenguaje C fue creado en 1972 por Ken L. Thompson y Dennis M. Ritchie en los Laboratorios Bell. Es evolución de un lenguaje más antiguo: B (a
Unidad Didáctica 2. Elementos básicos del lenguaje Java Tipos, declaraciones, expresiones y asignaciones
Unidad Didáctica 2 Elementos básicos del lenguaje Java Tipos, declaraciones, expresiones y asignaciones Fundamentos de Programación Departamento de Lenguajes y Sistemas Informáticos Versión 1.0.3 Índice
TEMA 5. CONTROL DE FLUJO DEL PROGRAMA. Sentencia Instrucción Expresión Operadores + Operandos Sintaxis: Sentencia ;
TEMA 5. CONTROL DE FLUJO DEL PROGRAMA 5.1 Sentencias Una sentencia es una expresión seguida de un punto y coma. Sentencia Instrucción Expresión Operadores + Operandos Sintaxis: Sentencia ; El ; es obligatorio
Isabelle como un lenguaje funcional
Capítulo 1 Isabelle como un lenguaje funcional 1.1 Introducción Nota 1.1.1. Esta notas son una introducción a la demostración asistida utilizando el sistema Isabelle/HOL/Isar. La versión de Isabelle utilizada
Programación 1. Tema I. Conceptos y elementos básicos de Programación. Lección 2. Lenguaje de programación y ejecución de un programa
Programación 1 Tema I. Conceptos y elementos básicos de Programación Lección 2. Lenguaje de programación y ejecución de un programa 1 Léxico, sintaxis y semántica de un lenguaje #include #include
Entrada y salida de datos en C y C++
Universidad Nacional de Rosario Facultad de Ciencias Exactas, Ingeniería y Agrimensura Escuela de Ingeniería Electrónica Cátedra de Informática II Entrada y salida de datos en C y C++ Informática II Entrada/Salida
GUÍA DE TRABAJO N 1 C# Ing. Néstor Raúl Suarez Perpiñan Página 1 de 13
Página 1 de 13 Tema: FUNDAMENTOS DE PROGRAMACIÓN EN LENGUAJE C# Objetivo: Conocer y manejar correctamente los tipos de datos y las diferentes estructuras de programación que hacen parte del lenguaje de
Guía 1: Funciones, precedencia y tipado
Introducción a los Algoritmos - do. cuatrimestre 014 Guía 1: Funciones, precedencia y tipado Docentes: Walter Alini, Luciana Benotti El objetivo de los siguientes ejercicios es introducirnos en la programación
Introducción a la Matemática Discreta
Introducción a la Matemática Discreta Lógica proposicional y Álgebras de Boole Luisa María Camacho Camacho Introd. a la Matemática Discreta 1 / 25 Introducción a la Matemática Discreta Temario Tema 1.
Informática Ingeniería en Electrónica y Automática Industrial
Informática Ingeniería en Electrónica y Automática Industrial Entrada y salida estándar V1.3 Autores Entrada y salida estándar Entradas y salidas Salida con formato: printf() Entrada de datos con formato:
APUNTES DE CÁTEDRA: ARREGLOS MULTIDIMENSIONALES
Facultad de Ciencias Exactas, Ingeniería y Agrimensura (U.N.R.) Escuela de Ciencias Exactas y Naturales Departamento de Matemática Cátedra: Computación (L.M. - P.M.) Prof. responsable: Mgr. María del Carmen
