Seguimos buscando a Arshak. Ayudanos compartiendo!
Encuesta no oficial de docentes
Resultados de la encuesta no oficial de docentes
Probaste el SIGA Helper?

Donar $100 Donar $200 Donar $500 Donar mensualmente


Enviar respuesta 
 
Calificación:
  • 0 votos - 0 Media
  • 1
  • 2
  • 3
  • 4
  • 5
Buscar en el tema
[Haskell] Dudas con listas
Autor Mensaje
Adolfito Sin conexión
Campeon del cubo Rubik
Sin estado :(
****

Ing. en Sistemas
Facultad Regional Buenos Aires

Mensajes: 114
Agradecimientos dados: 17
Agradecimientos: 13 en 7 posts
Registro en: Nov 2012
Mensaje: #1
[Haskell] Dudas con listas Ejercicios Paradigmas de Programación
hola, tengo dos dudas con el tema de listas:

la primera es: supongamos que tengo dos listas, como puedo hacer para saber si tienen elementos en comun ?

la segunda es: supongamos q tengo esta lista de tuplas : [("hola",1,2,3),("chau",4,5,6),("hasta luego",2,3,4)] y me piden por ejemplo que le sume 1 a la segunda componente de la tupla que contiene "hola","chau o "hasta luego" segun elija la persona que invoca la funcion, devolviendo la lista con esta modificacion. Como se puede hacer esto?
22-04-2014 18:11
Encuentra todos sus mensajes Agregar agradecimiento Cita este mensaje en tu respuesta
Diego Pedro Sin conexión
Secretario de la SAE
que calor no?
******

Ing. en Sistemas
Facultad Regional Buenos Aires

Mensajes: 631
Agradecimientos dados: 23
Agradecimientos: 105 en 48 posts
Registro en: May 2011
Mensaje: #2
RE: [Haskell] Dudas con listas
Para la primera vos queres saber solamente si tiene algun elemento en comun, o la lista de los que están en ambas. Si es el primer caso, podrías hacer:


tieneEnComun (x:xs) lista2 = elem x lista2 || tieneEnComun xs lista2


Para la segunda, tendrias una funcion que tiene 2 parametros, uno que es la palabra, y el otro que es tu lista. Deberias primero fijarte de los primeros elementos de tus tuplas cual coincide con tu palabra ingresada, y en esa tupla, sumarle 1.

Seria algo como


f palabra (x:xs) | palabra == primerElemento x = ((+1) . segundoElemento) x
| otherwise = f palabra xs

(Este mensaje fue modificado por última vez en: 22-04-2014 18:27 por Diego Pedro.)
22-04-2014 18:26
Envíale un email Encuentra todos sus mensajes Agregar agradecimiento Cita este mensaje en tu respuesta
Adolfito Sin conexión
Campeon del cubo Rubik
Sin estado :(
****

Ing. en Sistemas
Facultad Regional Buenos Aires

Mensajes: 114
Agradecimientos dados: 17
Agradecimientos: 13 en 7 posts
Registro en: Nov 2012
Mensaje: #3
RE: [Haskell] Dudas con listas
(22-04-2014 18:26)Diego Pedro escribió:  Para la primera vos queres saber solamente si tiene algun elemento en comun, o la lista de los que están en ambas. Si es el primer caso, podrías hacer:


tieneEnComun (x:xs) lista2 = elem x lista2 || tieneEnComun xs lista2


Para la segunda, tendrias una funcion que tiene 2 parametros, uno que es la palabra, y el otro que es tu lista. Deberias primero fijarte de los primeros elementos de tus tuplas cual coincide con tu palabra ingresada, y en esa tupla, sumarle 1.

Seria algo como


f palabra (x:xs) | palabra == primerElemento x = ((+1) . segundoElemento) x
| otherwise = f palabra xs


Y si en el primer caso las listas son elementos de dos tuplas seria lo mismo?
Y en el segundo caso, en un ejercicio me dan una funcion en la q los parametros no contienen a la lista. Es algo raro, como si tuvieramos q comparar en la lista si se encuentra la palabra y modificar en la lista la tupla q la contiene
(Este mensaje fue modificado por última vez en: 22-04-2014 22:20 por Adolfito.)
22-04-2014 22:05
Encuentra todos sus mensajes Agregar agradecimiento Cita este mensaje en tu respuesta
Diego Pedro Sin conexión
Secretario de la SAE
que calor no?
******

Ing. en Sistemas
Facultad Regional Buenos Aires

Mensajes: 631
Agradecimientos dados: 23
Agradecimientos: 105 en 48 posts
Registro en: May 2011
Mensaje: #4
RE: [Haskell] Dudas con listas
En el primer caso es lo mismo, fijate como está definida la función elem (en cuanto a tipos), y te vas a dar cuenta que pide comparar un elemento con una lista que sea de esos elementos, los cuales solo tienen la restriccion de ser comparables.

En el segundo caso, no entiendo bien que queres plantear, digamos si tu lista no es pasada como parametro tendría que venir de alguna otra funcón, sino deberias usar una expresión lambda para resolverlo.
23-04-2014 06:04
Envíale un email Encuentra todos sus mensajes Agregar agradecimiento Cita este mensaje en tu respuesta
Adolfito Sin conexión
Campeon del cubo Rubik
Sin estado :(
****

Ing. en Sistemas
Facultad Regional Buenos Aires

Mensajes: 114
Agradecimientos dados: 17
Agradecimientos: 13 en 7 posts
Registro en: Nov 2012
Mensaje: #5
RE: [Haskell] Dudas con listas
(23-04-2014 06:04)Diego Pedro escribió:  En el primer caso es lo mismo, fijate como está definida la función elem (en cuanto a tipos), y te vas a dar cuenta que pide comparar un elemento con una lista que sea de esos elementos, los cuales solo tienen la restriccion de ser comparables.

En el segundo caso, no entiendo bien que queres plantear, digamos si tu lista no es pasada como parametro tendría que venir de alguna otra funcón, sino deberias usar una expresión lambda para resolverlo.

la lista me la dan en el ejercicio digamos, y con esa funcion tendria q modificarla
23-04-2014 17:33
Encuentra todos sus mensajes Agregar agradecimiento Cita este mensaje en tu respuesta
Diego Pedro Sin conexión
Secretario de la SAE
que calor no?
******

Ing. en Sistemas
Facultad Regional Buenos Aires

Mensajes: 631
Agradecimientos dados: 23
Agradecimientos: 105 en 48 posts
Registro en: May 2011
Mensaje: #6
RE: [Haskell] Dudas con listas
La verdad necesitaria un ejemplo concreto para poder ayudarte, porque lo único que se me ocurre es lo que ya te dije que se hacía en tu consulta original.
23-04-2014 22:23
Envíale un email Encuentra todos sus mensajes Agregar agradecimiento Cita este mensaje en tu respuesta
Ichiluk Sin conexión
Campeon del cubo Rubik
Metametaprogramando.
****

Ing. en Sistemas
Facultad Regional Buenos Aires

Mensajes: 134
Agradecimientos dados: 5
Agradecimientos: 21 en 18 posts
Registro en: Apr 2008
Mensaje: #7
RE: [Haskell] Dudas con listas
ponele que tenés una lista que te dan en el enunciado:



naturales = [1..]


si vos tenés una función:

primerosQuinceDe lista = take 15 lista


si quisieras los primeros quince naturales, tenés que aplicar la lista que te dan:

primerosQuinceNaturales = primerosQuince naturales


Saludos!
(Este mensaje fue modificado por última vez en: 24-04-2014 14:57 por Ichiluk.)
24-04-2014 14:56
Encuentra todos sus mensajes Agregar agradecimiento Cita este mensaje en tu respuesta
rihardmarius Sin conexión
Secretario de la SAE
Por qué no me derivas el loga...
******

Ing. en Sistemas
Facultad Regional Buenos Aires

Mensajes: 416
Agradecimientos dados: 100
Agradecimientos: 412 en 67 posts
Registro en: Oct 2011
Mensaje: #8
RE: [Haskell] Dudas con listas
adolfito: me temo que el ejemplo que te dio pedro no funciona (el segundo caso), mira


f palabra (x:xs)
| palabra == fst x = ((+1) . snd) x
| otherwise = f palabra xs


si vos corres eso:

ghci> f 3 [(3,1),(3,2)]
2

aca te tiro algo simple pero que lo podes adaptar a listas de lo que quieras

-- multiplicar por 2 los elementos iguales a 3


modificar' [] = []
modificar' (x:xs)
| x == 3 = (2*x) : modificar' xs
| otherwise = x : modificar' xs


ghci> modificar' [1,2,3,4,5]
[1,2,6,4,5]


otra forma seria esta


modificar'' xs = map (\x -> if x == 3 then 2*x else x) xs


el problema es que la catedra desaprueba el uso de if then else, por lo tanto ese ejemplo es solo a modo ilustrativo

volviendo a tu ejemplo, aca te dejo la resolucion


lista = [("hola",1,2,3),("chau",4,5,6),("hasta luego",2,3,4)]

fst4 (x,_,_,_) = x
sumar (a,b,c,d) = (a,b+1,c,d)

modificar _ [] = []
modificar clave (x:xs)
| clave == fst4 x = sumar x : modificar clave xs
| otherwise = x : modificar clave xs


ghci> modificar "hola" lista
[("hola",2,2,3),("chau",4,5,6),("hasta luego",2,3,4)]
ghci> modificar "chau" lista
[("hola",1,2,3),("chau",5,5,6),("hasta luego",2,3,4)]
ghci> modificar "hasta luego" lista
[("hola",1,2,3),("chau",4,5,6),("hasta luego",3,3,4)]

(Este mensaje fue modificado por última vez en: 09-05-2014 16:59 por rihardmarius.)
09-05-2014 16:39
Encuentra todos sus mensajes Agregar agradecimiento Cita este mensaje en tu respuesta
guidobere Sin conexión
Empleado del buffet

*

Ing. en Sistemas
Facultad Regional Buenos Aires

Mensajes: 10
Agradecimientos dados: 1
Agradecimientos: 0 en 0 posts
Registro en: Nov 2011
Mensaje: #9
RE: [Haskell] Dudas con listas
(22-04-2014 18:26)Diego Pedro escribió:  Para la primera vos queres saber solamente si tiene algun elemento en comun, o la lista de los que están en ambas. Si es el primer caso, podrías hacer:


tieneEnComun (x:xs) lista2 = elem x lista2 || tieneEnComun xs lista2


deberias poner un caso base tambien porque la funcion esta es recursiva, sino le pones el caso base te tira un error de: 'non-exhaustive patterns...'

el caso base seria:

tieneEnComun [] lista = False

21-09-2014 19:21
Encuentra todos sus mensajes Agregar agradecimiento Cita este mensaje en tu respuesta
Buscar en el tema
Enviar respuesta 




Usuario(s) navegando en este tema: 1 invitado(s)