18. HaskellFOS

18. HaskellFOS - Lenguajes de programacin Funciones Lambda...

Info iconThis preview shows pages 1–4. Sign up to view the full content.

View Full Document Right Arrow Icon
Lenguajes de programación Funciones Lambda y Funciones de Orden Superior en Haskel Orden Superior en Haskell Lambdas en Haskell Funcionan igual que en Scheme Cuerpo Se escriben como: \x-> x * x Parámetro Se aplican igual (\x-> x * x) 5 => 25
Background image of page 1

Info iconThis preview has intentionally blurred sections. Sign up to view the full version.

View Full DocumentRight Arrow Icon
Ejercicio Hacer una expresión lambda que Hacer una expresión lambda que multiplique los componentes de un par: (\x->. ..) (2,3) => 6 Hint : la función fst da el primer elemento de una tupla, snd da el segundo, o sea, fst (2,3) => 2 snd (2,3) => 3 Ejemplo voltea La función voltea invierte el La función invierte el orden de los argumentos de una función binaria voltea div 6 2 => 0 div 6 2 => 3 Tipo de dato Función flip de Haskell Tipo de dato: voltea :: (a -> b -> c) -> b -> a -> c Solución: voltea = \f->(\x->(\y->f y x))
Background image of page 2
Funciones de orden superior Son funciones que se aplican a otras funciones Haskell tiene las FOS predefinidas map all, any filter foldl, foldl1 foldr, foldr1 . (compose) until map La función map aplica una función a todos los elementos de una lista y regresa el resultado en otra lista Recibe una función f: a b
Background image of page 3

Info iconThis preview has intentionally blurred sections. Sign up to view the full version.

View Full DocumentRight Arrow Icon
Image of page 4
This is the end of the preview. Sign up to access the rest of the document.

This note was uploaded on 05/12/2010 for the course ITC TC2006 taught by Professor Conant during the Spring '10 term at ITESM.

Page1 / 9

18. HaskellFOS - Lenguajes de programacin Funciones Lambda...

This preview shows document pages 1 - 4. Sign up to view the full document.

View Full Document Right Arrow Icon
Ask a homework question - tutors are online