Actualización de «Ordenación según una función»
He actualizado las soluciones del ejercicio «Ordenación según una función» cuyo enunciado es
Definir la función
ordenaSegun :: Ord b => (a -> b) -> [a] -> [a]
tal que (ordenaSegun f xs) es la lista obtenida ordenando los elementos de xs según sus valores mediante la función f. Por ejemplo,
ordenaSegun abs [-3,2,5,-2] == [2,-2,-3,5] ordenaSegun abs [-3,-2,5,2] == [-2,2,-3,5] ordenaSegun length ["pq","x","mn"] == ["x","pq","mn"] [g 0 | g <- ordenaSegun (\f -> f 4) [(+5),(+2),(+3)]] == [2,3,5]
Comprobar con QuickCheck que (ordenaSegun id) es equivalente a sort.
Nota: Puedes consultar las soluciones aquí.