data Tree a = Tip Node a (Tree a) (Tree a) deriving Show

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

Download "data Tree a = Tip Node a (Tree a) (Tree a) deriving Show"

Transcripción

1 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 _ Tip = Tip cambiar [] (Node xs t1 t2) = Node (reverse xs) (cambiar [] t1) (cambiar [] t2) cambiar (x:xs) (Node ys t1 t2) = Node (x:xs) (cambiar (x:xs) t2) (cambiar (x:xs) t1) La evaluación de la expresión: cambiar [1,2,3] (Node [-1,-2,-3] (Node [0] Tip Tip) (Node [4,8] Tip Tip)) da como resultado: Pregunta 2 Sea la expresión: a) Node [0] (Node [1,2,3] Tip Tip) (Node [1,2,3] Tip Tip) b) Node [1,2,3] (Node [1,2,3] Tip Tip) (Node [1,2,3] Tip Tip) c) Node [3,2,1] (Node [3,2,1] Tip Tip) (Node [3,2,1] Tip Tip) d) Node [] (Node [] Tip Tip) (Node [] Tip Tip) tata = map (mod 0) [1,2,0,7,8] Indique cuáles de las siguientes expresiones produce un error al ser evaluada Pregunta 3 a) last tata b) head tata c) foldl (*) 3 tata d) length tata Sea la siguiente definición lolo g x = ys where ys = [x] ++ filter (curry g x) ys El tipo de la función lolo es: a) (a,b) -> Bool -> b -> [(a,b)] b) (b -> b -> b) -> Bool -> [b] c) ((b,b) -> Bool) -> b -> [b] d) (a -> b -> Bool) -> b -> [c] Pregunta 4 La expresión take 5 (lolo (uncurry (==)) 1) da como resultado: a) [] b) [(1,1), (1,1), (1,1), (1,1), (1,1)] c) [1, 1, 1, 1, 1] d) [((((1,1), 1), 1), 1)]

2 Pregunta 5 Considere las siguientes expresiones: i) (foldr (.)) ii) ((.) foldr) iii) (foldr. (.)) iv) ((.). foldr) Indique cuál de las siguientes afirmaciones es correcta: Pregunta 6 a) (ii) no tiene tipo y todas las otras sí. b) (iii) y (iv) tienen tipo y las otra no. c) Ninguna de las expresiones tiene tipo. d) Todas las expresiones tienen tipo. Se consideran las siguientes expresiones: a) (flip.) b) (. flip) c) (.) flip d) (.) $ flip e) flip $ (.) Indique cuál de las siguientes afirmaciones es correcta: a) Las expresiones b) y c) tienen el mismo tipo b) Las expresiones c) y d) tienen el mismo tipo c) La expresión d) no tiene tipo d) Las expresiones e) y a) tienen el mismo tipo Pregunta 7 Sea la expresión foldl ope 0 [5,7,3] where ope n x = 10 * n + x Cual de las siguientes afirmaciones acerca de la evaluación de la expresión es correcta? Pregunta 8 a) el resultado es el mismo si cambiamos foldl por foldr b) el resultado es [5,7,3] c) el resultado es [3,7,5] d) el resultado es 573 Dada la siguiente definición, indique cuál de las siguientes afirmaciones es correcta: fibs ::[Int] fibs = 0 : 1 : zipwith (+) fibs (tail fibs) a) fibs define una lista finita b) La evaluación de fibs produce un error de tipo c) fibs define la lista de los números de Fibonacci d) fibs define una lista infinita de números impares

3 Pregunta 9 Sea la siguiente definición de función: pepe _ [] = [] pepe y (x:xs) y == x = xs' otherwise = y:xs' where xs' = pepe y xs El tipo más general para esta función es: Pregunta 10 a) (Eq a) => a -> [a] -> [a] b) Int -> [Int] -> [Int] c) (Eq a, Eq b) => b -> [a] -> [a] d) (Ord a) => a -> [a] -> [a] Indique cuál de las siguientes expresiones no tiene tipo (la función pepe está definida en la pregunta 9): Pregunta 11 a) (pepe "hola") b) (pepe "hola" "chau") c) (pepe. head) d) (map. pepe) Indique cuál de las siguientes afirmaciones es correcta (la función pepe está definida en la pregunta 9) Pregunta 12 a) (pepe 'a' "hol")>>> da como resultado "hola" b) (pepe 1 [1,1,1,1])>>> da el mismo resultado que pepe 1 [1] c) (pepe 1 [1,2])>>> da como resultado [] d) (pepe 1 [2])>>> da como resultado [2] Considere la siguiente definición: foo :: (Num a) => Int -> a -> a foo 0 = constante 1 foo (n+1) = combinar (*) (foo n) constante x _ = x combinar f g x = f x (g x) El resultado de la evaluación de (foo 4 2) es a) 16 b) 4 c) 2 d) 8

4 Pregunta 13 Sea la siguiente definición: cc xs ys = [ x x <- xs, y <- ys, x <= y] Indicar cuál es el resultado de evaluar la expresión: let us = [1,1] in cc us us a) [] b) [1,1,1] c) [1,1,1,1] d) [1,1] Pregunta 14 Sea la siguiente definición: f xs = [i i <- xs, (i,j) <- map (\y -> (i,y)) xs, i > j] Cual es el resultado de evaluar f [1,2,3]? Pregunta 15 a) [2,3] b) [2,3,3] c) [3,3,3] d) [1,2,3] Dada la expresión e = (foldr (++). map (:)) [1,2,3] [[filter even]] Cuál de las siguientes afirmaciones es correcta: a) e no tiene tipo b) head e [5,6] es [6] c) el tipo de e es [[Integer]] -> [[Integer]] d) head e [] es [[]] Pregunta 16 Sea la definición posi a l l1 /= [] = Just (head l1) otherwise = Nothing where l1 = [i (i,j) <- zip [0.. (length l)] l, j == a] Indique el tipo más general de posi: a) Maybe Int -> [Int] -> Maybe Int b) (Eq a) => a -> [a] -> Maybe Int c) (Eq a) => a -> [a] -> Maybe a d) Maybe a -> [Maybe a] -> Maybe Int

5 Pregunta 17 Dada la expresión zipwith. uncurry, cuál de las siguientes afirmaciones es correcta? a) el tipo de la expresión es [a -> b -> c] -> [(a,b)] -> [c] b) el tipo de la expresión es (a -> b -> c -> d) -> [(a,b)] -> [c] -> [d] c) la expresión no tiene tipo d) el tipo de la expresión es (a -> b -> c) -> ([a],[b]) -> [c] Pregunta 18 Pregunta 19 Se considera la siguiente definición de árboles data Rose a = Fork a [Rose a] Se quiere definir la función member, que verifica si un elemento aparece en un árbol member :: Eq a => a -> Rose a -> Bool Indique cuál de las siguientes definiciones de member es correcta: a) member a (Fork r ts) = if a == r then True else elem r ts b) member a (Fork r ts) = a == r map (==a) ts c) member a (Fork r ts) = r == a any (member a) ts d) member a (Fork r ts) = if a==r then True else member a ts Sea la siguiente expresión: (!!) (scanl mod 1 [0..4]) 1 Cuál de las siguientes afirmaciones es correcta? Pregunta 20 a) la evaluación de la expresión produce un error b) la evaluación de la expresión da como resultado 0 c) la expresión no tiene tipo d) la evaluación de la expresión da como resultado 1 Sea la siguiente definición: f xss = \a -> let ope x y = x ++ [a] ++ y in foldr1 ope xss Cuál es el resultado de evaluar f [[1,3],[2,4], [0,9,8]] 5? a) [[1,5,3], [2,5,4],[0,5,9,5,8]] b) [[1,3],[5],[2,4],[5], [0,9,8]] c) [1,3,5,2,4,5,0,9,8] d) [[1,3,5,2,4,5,0,9,8]]

6 Pregunta 21 Dadas las siguientes definiciones: data Nat = Cero Suc Nat instance Show Nat where show Cero = "0" show (Suc Cero) = "1" show (Suc n) = "1 + " ++ (show n) ++ "\n" suma :: Nat -> Nat-> Nat suma Cero n = n suma (Suc n) m = Suc (suma n m) Cuál de las siguientes afirmaciones es correcta? a) el tipo de suma debe ser (Show Nat) => Nat -> Nat-> Nat b) las definiciones son correctas c) en la declaración del tipo falta deriving Show d) el tipo de suma debe ser (Num Nat) => Nat -> Nat-> Nat

Tema 11. Listas infinitas

Tema 11. Listas infinitas Programación Declarativa Haskell Informática Sistemas Curso 2003-2004 Pepe Gallardo Universidad de Málaga Tema 11. Listas infinitas 11.1 Listas infinitas 11.2 La criba de Eratóstenes 11.3 Redes de procesos

Más detalles

Programación Funcional

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

Más detalles

Programación Funcional en Haskell

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

Más detalles

SOLUCIONES A EJERCICIOS

SOLUCIONES A EJERCICIOS 21 SOLUCIONES A EJERCICIOS 21.1. INTRODUCCIÓN A HASKELL Solución al Ejercicio 2.14 (pág. 33). Nuestra función deberá verificar n sep n 0 aentero [a n, a n 1,..., a 0 ] = n i=0 a i 10 i Para n = 0 tenemos

Más detalles

Programación con listas. El tipo lista

Programación con listas. El tipo lista Capítulo 6. Programación con listas 68 Programación con listas El tipo lista La lista representa colecciones de objetos homogéneas (todos los objetos han de tener el mismo tipo). infixr 5 : data [a] =

Más detalles

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 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

Más detalles

Tema 13: Programas interactivos

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

Más detalles

Programación declarativa ( )

Programación declarativa ( ) 1 / 132 Programación declarativa (2008 09) Tema 3: Estructuras de datos José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla 2 /

Más detalles

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 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

Más detalles

Práctica N o 1 - Programación Funcional

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

Más detalles

Informática Haskell Matemáticas Curso Pepe Gallardo Universidad de Málaga. Tema 8. Listas

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

Más detalles

Exámenes de Programación funcional con Haskell ( )

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

Más detalles

Introducción. Haskell

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 ( :: )

Más detalles

Tipos en Haskell. Cecilia Manzino

Tipos en Haskell. Cecilia Manzino Tipos Tipo: conjunto de valores asociados a operaciones. Ejemplos: enteros, caracteres, booleanos, funciones de enteros a enteros. Sirven para: detectar errores antes de la evaluación especificar programas

Más detalles

Ejercicios de programación funcional con Haskell

Ejercicios de programación funcional con Haskell Ejercicios de programación funcional con Haskell José A. Alonso Jiménez Grupo de Lógica Computacional Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Sevilla, 8 de

Más detalles

Tema 1. Tema 2. Informática Haskell Matemáticas Curso Pepe Gallardo Universidad de Málaga

Tema 1. Tema 2. Informática Haskell Matemáticas Curso Pepe Gallardo Universidad de Málaga Informática Pepe Gallardo Universidad de Málaga 1 Informática Haskell Matemáticas Curso 2004-2005 Pepe Gallardo Universidad de Málaga Tema 1 1.1 Considérense las siguientes definiciones de funciones: inc

Más detalles

Tema 23: Técnicas de diseño descendente de algoritmos

Tema 23: Técnicas de diseño descendente de algoritmos Tema 23: Técnicas de diseño descendente de algoritmos 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

Más detalles

Programación Declarativa Haskell Informática Sistemas Curso Pepe Gallardo Universidad de Málaga

Programación Declarativa Haskell Informática Sistemas Curso Pepe Gallardo Universidad de Málaga Programación Declarativa Haskell Informática Sistemas Curso 2008-2009 Pepe Gallardo Universidad de Málaga Tema 1 1.1 Considérense las siguientes definiciones de funciones: inc :: Float Float inc x = x

Más detalles

Ejercicios de programación funcional con Haskell

Ejercicios de programación funcional con Haskell Ejercicios de programación funcional con Haskell José A. Alonso Jiménez Grupo de Lógica Computacional Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Sevilla, 8 de

Más detalles

Tema 21: Algoritmos de exploración de grafos

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:

Más detalles

Tema 9: Declaraciones de tipos y clases

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

Más detalles

Tema 9: Declaraciones de tipos y clases

Tema 9: Declaraciones de tipos y clases Tema 9: Declaraciones de 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 / 41 Tema 9:

Más detalles

Tema 6: Funciones recursivas

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

Más detalles

Tema 8: Funciones de orden superior

Tema 8: Funciones de orden superior Tema 8: Funciones de orden superior 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

Más detalles

Tema 8: Funciones de orden superior

Tema 8: Funciones de orden superior Tema 8: Funciones de orden superior 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 2 /

Más detalles

Secuencias. Mauro Jaskelioff 18/05/2015

Secuencias. Mauro Jaskelioff 18/05/2015 Secuencias Mauro Jaskelioff 18/05/2015 Secuencias Seq es un TAD para representar secuencias de elementos. A continuación veremos algunas de sus operaciones y las especificaremos en términos de la noción

Más detalles

El sistema de clases de Haskell. Introducció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

Más detalles

Tema 7. El sistema de clases

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

Más detalles

Estructuras de Datos. Dr. Pablo E. Fidel Martínez López Lic. en Ciencias de la Computación UNR

Estructuras de Datos. Dr. Pablo E. Fidel Martínez López Lic. en Ciencias de la Computación UNR Estructuras de Datos Dr. Pablo E. Fidel Martínez López Lic. en Ciencias de la Computación UNR ...but note that an implementation need not be actualized as code a concrete design is sufficient. Chris Okasaki

Más detalles

Recursividad: piezas básicas para la interpretación y la optimización. Cristóbal Pareja Flores Universidad Complutense de Madrid

Recursividad: piezas básicas para la interpretación y la optimización. Cristóbal Pareja Flores Universidad Complutense de Madrid Recursividad: piezas básicas para la interpretación y la optimización Cristóbal Pareja Flores cpareja@sip.ucm.es Universidad Complutense de Madrid 1. Recursividad imagen = dos personas + un espejo con

Más detalles

Programación Declarativa UNIVERSIDAD DE MÁLAGA

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 Septiembre de 2006 mbre: Especialidad: Prolog Grupo: Ejercicio 1.1 (1 punto) Realizad el árbol

Más detalles

Programación Declarativa UNIVERSIDAD DE MÁLAGA

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

Más detalles

ALPII Práctica 3. Bernardo García Fuentes

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

Más detalles

Lógica y Programación

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

Más detalles

Tema 2: Introducción a la programación con Haskell

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

Más detalles

Tema Árboles binarios fmap para árboles binarios Plegado de árboles binarios

Tema Árboles binarios fmap para árboles binarios Plegado de árboles binarios Programación Declarativa Haskell Informática Sistemas Curso 2003-2004 Pepe Gallardo Universidad de Málaga Tema 9. Árboles 9.1 Árboles binarios fmap para árboles binarios Plegado de árboles binarios 9.2

Más detalles

Tecnólogo Informático- Estructuras de Datos y Algoritmos- 2009

Tecnólogo Informático- Estructuras de Datos y Algoritmos- 2009 Árboles Ejemplos de estructuras arborescentes: con forma de árbol Regla de Alcance: los objetos visibles en un procedimiento son aquellos declarados en él mismo o en cualquier ancestro de él (cualquier

Más detalles

Introducción a la Programación Genérica

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

Más detalles

Introducción a Haskell. Cecilia Manzino

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:

Más detalles

Para entender la recursividad primero tenemos que entender la recursividad

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

Más detalles

Tema 5: Definiciones de listas por comprensión

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

Más detalles

Tema 5: Definiciones de listas por comprensión

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

Más detalles

Estructuras de Datos. Dr. Pablo E. Fidel Martínez López Lic. en Ciencias de la Computación UNR

Estructuras de Datos. Dr. Pablo E. Fidel Martínez López Lic. en Ciencias de la Computación UNR Estructuras de Datos Dr. Pablo E. Fidel Martínez López Lic. en Ciencias de la Computación UNR In contrast, functional implementations of these data structures abstract away from troublesome pointer manipulations

Más detalles

Tema 4: Definición de 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

Más detalles

Guía 2: Listas, recursión e inducción

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

Más detalles

Tema 4: Definición de funciones

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

Más detalles

Tema 13: Aplicaciones de programación funcional

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

Más detalles

Isabelle como un lenguaje funcional

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

Más detalles

Ejemplos de conversión de reales a enteros

Ejemplos de conversión de reales a enteros Ejemplos de conversión de reales a enteros Con el siguiente programa se pueden apreciar las diferencias entre las cuatro funciones para convertir de reales a enteros: program convertir_real_a_entero print

Más detalles

Paradigmas de Programación

Paradigmas de Programación Paradigmas de Programación 4. Paradigma Funcional Departamento de Informática Universidad de Valladolid Curso 2010-11 Grado en Ingeniería Informática Grado en Ingeniería Informática de Sistemas 11 Feb.

Más detalles

Listas y Recursión. Taller de Álgebra I. Primer Cuatrimestre de 2015

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]

Más detalles

Programación Funcional

Programación Funcional Programación Funcional 2 Tabla de Contenidos 0.1. Evolución y Conceptos básicos................... 4 0.2. Definición de funciones........................ 4 0.3. Sistema de Tipos...........................

Más detalles

Polinomios. Taller de Álgebra I. Verano 2017

Polinomios. Taller de Álgebra I. Verano 2017 Polinomios Taller de Álgebra I Verano 2017 Polinomios En esta clase vamos a trabajar con polinomios. Para hacer las cosas fáciles, trabajaremos en R[x]. Es decir, en Float[x]. Hay muchas maneras de representar

Más detalles

Guía 2: Funciones, listas, recursión e inducción

Guía 2: Funciones, listas, recursión e inducción Introducción a los Algoritmos - 1er cuatrimestre 2013 Guía 2: Funciones, listas, recursión e inducción El objetivo de los siguientes ejercicios es introducirnos en la programación funcional, es decir,

Más detalles

1.1 Define un operador ( ) que devuelva True si y solo si tan solo uno de sus argumentos es True. Por ejemplo:? (3 > 2) (2 > 5)

1.1 Define un operador ( ) que devuelva True si y solo si tan solo uno de sus argumentos es True. Por ejemplo:? (3 > 2) (2 > 5) 1 Informática Haskell Matemáticas Curso 2004-2005 Pepe Gallardo Universidad de Málaga Práctica 1 1.1 Define un operador ( ) que devuelva True si y solo si tan solo uno de sus argumentos es True. Por ejemplo:?

Más detalles

n! = 1 2 n 0! = 1 (n+1)! = (n + 1) n!

n! = 1 2 n 0! = 1 (n+1)! = (n + 1) n! Capítulo 3 Recursión La recursión es un estilo autoreferencial de definición usado tanto en matemática como en informática. Es una herramienta de programación fundamental, particularmente importante para

Más detalles

Tema 12: Programas interactivos

Tema 12: Programas interactivos Tema 12: Programas interactivos 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 12:

Más detalles

Programación Funcional Haskell Clase 22

Programación Funcional Haskell Clase 22 Programación Funcional Haskell Clase 22 José Raymundo Marcial Romero rmarcial@fi.uaemex.mx BUAP c José Raymundo Marcial Romero. Clase Número 22 p.1/?? Temas de la clase Tipos Numéricos de Haskell Tipos

Más detalles

Tema 6. Definiciones de tipos

Tema 6. Definiciones de tipos Programación Declarativa Haskell Informática Sistemas Curso 2003-2004 Pepe Gallardo Universidad de Málaga Tema 6. Definiciones de tipos 6.1 Sinónimos de tipo 6.2 Definiciones de tipos de datos Tipos enumerados

Más detalles

3.- DETERMINANTES. a 11 a 22 a 12 a 21

3.- DETERMINANTES. a 11 a 22 a 12 a 21 3.- DETERMINANTES. 3.1. -DEFINICIÓN Dada una matriz cuadrada de orden n, se llama determinante de esta matriz (y se representa por A o deta al polinomio cuyos términos son todos los productos posibles

Más detalles

Tesis de Maestría en Informática

Tesis de Maestría en Informática PEDECIBA Informática Instituto de Computación Facultad de Ingeniería Universidad de la República Montevideo, Uruguay Tesis de Maestría en Informática Fusión en presencia de acumuladores Amarante 2010 Martínez

Más detalles

SOLUCIONES A LOS EJERCICIOS DE EXÁMENES

SOLUCIONES A LOS EJERCICIOS DE EXÁMENES 19 SOLUCIONES A LOS EJERCICIOS DE EXÁMENES 19.1. AÑO 1996 Solución al Ejercicio 18.1 (pág. 513). (A). h p = foldr (λ x u if p x then x : u else u) [ ] (B). Una posible función, sin utilizar la función

Más detalles

XML y XQuery. Qué es XML? Qué es XML? (II) Ejemplo de fichero XML. Cuerpo de un documento XML. Estructura de un documento XML

XML y XQuery. Qué es XML? Qué es XML? (II) Ejemplo de fichero XML. Cuerpo de un documento XML. Estructura de un documento XML Qué es XML? XML y XQuery BDSI 2008/09 Rafael Caballero Conjunto de reglas para definir lenguajes de marcado específicos No se trata de un lenguaje, sino de un metalenguaje XML no es: HTML: : Lenguaje de

Más detalles

Escuela Politécnica Superior de Ingeniería Departamento de Ingeniería Informática

Escuela Politécnica Superior de Ingeniería Departamento de Ingeniería Informática Escuela Politécnica Superior de Ingeniería Departamento de Ingeniería Informática Fundamentos de la informática 2. Algoritmos, diagramas de flujo y pseudocódigo Contenido Algoritmos Diagramas de flujo

Más detalles

Árboles generales. Un árbol es una estructura no lineal acíclica utilizada para organizar información de forma eficiente. La definición es recursiva:

Árboles generales. Un árbol es una estructura no lineal acíclica utilizada para organizar información de forma eficiente. La definición es recursiva: Capítulo 9. Programación con Árboles 107 Árboles Árboles generales Un árbol es una estructura no lineal acíclica utilizada para organizar información de forma eficiente. La definición es recursiva: Un

Más detalles

Nota 2. Luis Sierra. Marzo del 2010

Nota 2. Luis Sierra. Marzo del 2010 Nota 2 Luis Sierra Marzo del 2010 Cada mecanismo de definición de conjuntos que hemos comentado sugiere mecanismos para definir funciones y probar propiedades. Recordemos brevemente qué son las funciones

Más detalles

Temas de Programación funcional (curso )

Temas de Programación funcional (curso ) Temas de Programación funcional (curso 2009 10) José A. Alonso Jiménez Grupo de Lógica Computacional Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Sevilla, 3 de Septiembre

Más detalles

Examen final de CL 11 de Enero de 2012 Fecha de publicación de notas: 19-1-2012 Fecha de revisión: 20-1-2012

Examen final de CL 11 de Enero de 2012 Fecha de publicación de notas: 19-1-2012 Fecha de revisión: 20-1-2012 Examen final de CL 11 de Enero de 2012 Fecha de publicación de notas: 19-1-2012 Fecha de revisión: 20-1-2012 Sin apuntes. Tiemp: 3h. Nombre y Apellidos: Problema de analisis léxico, sintáctico e intérpretes

Más detalles

Ejercicios de Funciones, límites y continuidad.

Ejercicios de Funciones, límites y continuidad. Matemáticas 1ºBach CNyT. Ejercicios Funciones. Pág 1/12 Ejercicios de Funciones, límites y continuidad. 1. Estudia el dominio de las siguientes funciones 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14.

Más detalles

Tema Árboles generales. 9.2 Árboles binarios 9.3 Árboles de búsqueda

Tema Árboles generales. 9.2 Árboles binarios 9.3 Árboles de búsqueda Informática Haskell Matemáticas Curso 2004-2005 Pepe Gallardo Universidad de Málaga Tema 9. Árboles 9.1 Árboles generales 9.2 Árboles binarios 9.3 Árboles de búsqueda 9.1 Árboles generales Un árbol es

Más detalles

También añado a la clase Libro los siguientes métodos: (que programaré más adelante)

También añado a la clase Libro los siguientes métodos: (que programaré más adelante) 1.Creación de la capa de negocios La capa del Dominio de Negocios consta de una clase creada a partir de la tabla Libro a la que le he añadido los atributos no persistentes: CodPais, artic y digcontrol.

Más detalles

Tipos paramétricos y recursivos

Tipos paramétricos y recursivos Tipos paramétricos y recursivos Taller de Álgebra I Verano 2017 Tipos paramétricos Tipos paramétricos Podemos hacer que los constructores de un tipo de datos reciban parámetros. A los tipos construidos

Más detalles

Valores Booleanos Interpretación #t Cierto #f Falso --------------------------------------------------------------------

Valores Booleanos Interpretación #t Cierto #f Falso -------------------------------------------------------------------- Valores Booleanos Interpretación #t Cierto #f Falso -------------------------------------------------------------------- Números Pueden ser Complejos Reales Racionales Enteros -------------------------------

Más detalles

Curso 0 de Informática

Curso 0 de Informática Curso 0 de Informática 2015-2016 Tema 1: Introducción a la Informática y Conceptos básicos 1 Motivación (I): En los procesos industriales, cada vez es mayor el uso de sistemas informáticos para: Monitorización,

Más detalles

Tema 3: Tipos y clases

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

Más detalles

Tema 3: Tipos y clases

Tema 3: Tipos y clases Tema 3: Tipos y clases Informática (2017 18) 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

Más detalles

Temas de Programación funcional (curso )

Temas de Programación funcional (curso ) 1 Temas de Programación funcional (curso 2017 18) José A. Alonso Jiménez Grupo de Lógica Computacional Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Sevilla, 5 de

Más detalles

Temas de Programación funcional (curso )

Temas de Programación funcional (curso ) 1 Temas de Programación funcional (curso 2018 19) José A. Alonso Jiménez Grupo de Lógica Computacional Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Sevilla, 12 de

Más detalles

Temas de Programación funcional (curso )

Temas de Programación funcional (curso ) Temas de Programación funcional (curso 2011 12) José A. Alonso Jiménez Grupo de Lógica Computacional Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Sevilla, 24 de

Más detalles

Temas de Programación declarativa ( ) José A. Alonso Jiménez

Temas de Programación declarativa ( ) José A. Alonso Jiménez Temas de Programación declarativa (2007 08) José A. Alonso Jiménez Grupo de Lógica Computacional Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Sevilla, 28 de Agosto

Más detalles

Tema 3: Tipos y clases

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

Más detalles

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

Más detalles

Práctico 5. Definiciones Inductivas - Segunda Parte -

Práctico 5. Definiciones Inductivas - Segunda Parte - Práctico 5 Definiciones Inductivas - Segunda Parte - Objetivos: Trabajar con tipos inductivos. Realizar pruebas por inducción y análisis de casos. Familiarizarse con los lemas de inversión y las tácticas

Más detalles

PARADIGMAS DE LENGUAJES DE PROGRAMACIÓN. Programación Funcional. Pablo E. Fidel Martínez López

PARADIGMAS DE LENGUAJES DE PROGRAMACIÓN. Programación Funcional. Pablo E. Fidel Martínez López PARADIGMAS DE LENGUAJES DE PROGRAMACIÓN Programación Funcional Pablo E. Fidel Martínez López Cuando sepas reconocer la cuatrifolia en todas sus sazones, raíz, hoja y flor, por la vista y el olfato, y la

Más detalles

Tema II: Introducción al Lenguaje Funcional

Tema II: Introducción al Lenguaje Funcional Tema II: Introducción al Lenguaje Funcional Características de Haskell Lenguaje funcional de o. superior fuertemente tipificado. Clasifica los entes de un programa en: objetos (constantes y funciones)

Más detalles

Prácticas de Programación Declarativa ( )

Prácticas de Programación Declarativa ( ) Prácticas de Programación Declarativa (2007 08) José A. Alonso Jiménez Grupo de Lógica Computacional Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Sevilla, 16 de

Más detalles

Ejercicios de Informática de 1 o de Matemáticas ( )

Ejercicios de Informática de 1 o de Matemáticas ( ) Ejercicios de Informática de 1 o de Matemáticas (2011 12) José A. Alonso Jiménez Grupo de Lógica Computacional Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Sevilla,

Más detalles

Programación Funcional Haskell Clase 21

Programación Funcional Haskell Clase 21 Programación Funcional Haskell Clase 21 José Raymundo Marcial Romero rmarcial@fi.uaemex.mx BUAP c José Raymundo Marcial Romero. Clase Número 21 p.1/12 Temas de la clase Clase Anterior En Haskell cada expresión

Más detalles

Introducción a OCaml. October 19, 2015

Introducción a OCaml. October 19, 2015 Introducción a OCaml October 19, 2015 OCaml: introducción Es un dialecto de ML. Lenguaje de programación funcional. Fuertemente tipado. Con inferencia de tipos. Polimórfico. [Página oficial: http://www.ocaml.org/

Más detalles

Ejercicios de Informática de 1º de Matemáticas ( ) José A. Alonso Jiménez

Ejercicios de Informática de 1º de Matemáticas ( ) José A. Alonso Jiménez Ejercicios de Informática de 1º de Matemáticas (2016 17) José A. Alonso Jiménez Grupo de Lógica Computacional Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Sevilla,

Más detalles

Programación Funcional

Programación Funcional Programación Funcional Jeroen Fokker 1996 Universidad de Utrecht Departamento de Informática Traducci on: Programa MEMI Universidad Mayor de San Simón Hielko R. Ophoff & Bernardo Sánchez J. Revisión: Universidad

Más detalles

OPERADORES LÓGICOS Y DE COMPARACIÓN EN PHP. PRIORIDADES. EJEMPLOS. EJERCICIOS RESUELTOS. (CU00818B)

OPERADORES LÓGICOS Y DE COMPARACIÓN EN PHP. PRIORIDADES. EJEMPLOS. EJERCICIOS RESUELTOS. (CU00818B) APRENDERAPROGRAMAR.COM OPERADORES LÓGICOS Y DE COMPARACIÓN EN PHP. PRIORIDADES. EJEMPLOS. EJERCICIOS RESUELTOS. (CU00818B) Sección: Cursos Categoría: Tutorial básico del programador web: PHP desde cero

Más detalles

Árboles. Cursos Propedéuticos 2015. Dr. René Cumplido M. en C. Luis Rodríguez Flores

Árboles. Cursos Propedéuticos 2015. Dr. René Cumplido M. en C. Luis Rodríguez Flores Árboles Cursos Propedéuticos 2015 Dr. René Cumplido M. en C. Luis Rodríguez Flores Contenido de la sección Introducción Árbol genérico Definición y representación Árboles binarios Definición, implementación,

Más detalles

Resumen de los tipos abstractos de datos

Resumen de los tipos abstractos de datos Resumen de los tipos abstractos de datos José A. Alonso Jiménez Grupo de Lógica Computacional Dpto. de Ciencias de la Computación e I.A. Universidad de Sevilla 18 de agosto de 2015 Resumen Es este documento

Más detalles

Programación declarativa ( )

Programación declarativa ( ) Programación declarativa (2008 09) Tema 1: Programación funcional básica José A. Alonso Jiménez Grupo de Lógica Computacional Departamento de Ciencias de la Computación e I.A. Universidad de Sevilla 1

Más detalles

Estructuras de repetición hacer-mientras y repita hasta

Estructuras de repetición hacer-mientras y repita hasta Estructuras de repetición hacer-mientras y repita hasta Programación 1 Cátedra de Programación Departamento de Computación Escuela de Ingeniería de Sistemas Hacer mientras Diagrama de flujo Acciones S1

Más detalles