IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Caml Discussion :

le maximum dans une liste


Sujet :

Caml

  1. #1
    Nouveau membre du Club
    Inscrit en
    Avril 2009
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 40
    Points : 30
    Points
    30
    Par défaut le maximum dans une liste
    bonjour,
    voila ,
    je suis débutant en caml et je dois résoudre se problème
    mon pb: retourner le maximum dans une liste
    jusqu'ici , voici mon code ::

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    let max2 x y = if x>y then x else y ;;
    
    let rec max_list l= match l with 
    [] -> ??????
    |x::reste -> max2 x (max_list reste) ;;
    je compare deux a deux et a la fin j'ai le maximum mais quoi mettre dans ????? et est-ce le bon code pour ce pb, mrc pour vos réponses...

  2. #2
    Nouveau membre du Club
    Inscrit en
    Avril 2009
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 40
    Points : 30
    Points
    30
    Par défaut résultat
    c'est bon j'ai trouver , pour ceux qui la voudraient :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    let max2 x y = if x>y then x else y;;
     
    let rec max_list l = match l with 
    [] -> 0 
    |x::reste -> max2 x (max_list reste) ;;




    merci quand même pour ceux qui ont essayer

  3. #3
    alex_pi
    Invité(e)
    Par défaut
    teste ta fonction sur la liste [-1; -2] pour voir ?

  4. #4
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    Essayer d'attribuer un maximum à une liste vide n'a pas de sens, excepté peut-être si tu peux représenter moins l'infini dans ton système de numération, et encore... A priori, une fonction maximum devrait juste échouer (avec une exception) dans ce cas, pas renvoyer un mensonge comme 0.

    En Haskell :
    Code Haskell : Sélectionner tout - Visualiser dans une fenêtre à part
    maximum = foldl1' max
    Sachant que foldl1' est une version stricte de foldl1 qui lui-même est un foldl restreint aux listes non-vides :
    Code Haskell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    foldl1 :: (a -> a) -> [a] -> a
    foldl1 f (x:xs) = foldl f x xs
    foldl1 _ []     = undefined
    Rappelons que foldl est l'équivalent de fold_left en OCaml :
    Code Haskell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    foldl :: (a -> b) -> a -> [b] -> a
    foldl f z []     = z
    foldl f z (x:xs) = foldl f (f z x) xs

    --
    Jedaï

  5. #5
    alex_pi
    Invité(e)
    Par défaut
    @Jedai: confronté à quelqu'un débutant *clairement* dans le domaine de l'algorithmique et de la programmation en général, et en tout cas dans celui de la programmation fonctionnelle, je ne suis vraiment pas sûr que lui balancer une syntaxe différente, autant pour les termes que pour les types, soit un choix pédagogiquement intéressant... :-\

  6. #6
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    La syntaxe n'est pas très différente néanmoins ? Ok, en OCaml, ça donnerait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    let max x y = if x < y then y else x
    let maximum = function
      | x :: xs -> List.fold_left max x xs
      | [] -> failwith "maximum of an empty list !\n"
    Mais bon, c'est pratiquement la même chose.

    --
    Jedaï

  7. #7
    Membre émérite
    Avatar de SpiceGuid
    Homme Profil pro
    Inscrit en
    Juin 2007
    Messages
    1 704
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 704
    Points : 2 991
    Points
    2 991
    Par défaut
    Une solution casuistique (qui préserve la structure de monoïde) :
    Code OCaml : Sélectionner tout - Visualiser dans une fenêtre à part
    let list_max l = List.fold_right max l

  8. #8
    alex_pi
    Invité(e)
    Par défaut
    Citation Envoyé par SpiceGuid Voir le message
    Une solution casuistique (qui préserve la structure de monoïde) :
    Code OCaml : Sélectionner tout - Visualiser dans une fenêtre à part
    let list_max l = List.fold_right max l
    Euh, c'est quoi l'intérêt de prendre le fold non tail_rec ?

  9. #9
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    Citation Envoyé par alex_pi Voir le message
    Euh, c'est quoi l'intérêt de prendre le fold non tail_rec ?
    En Haskell ça pourrait avoir un intérêt si max n'était pas strict en son second argument, par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    max True _ = True
    max False b = b
    (max == (||) dans ce cas, mais on peut imaginer plus complexe)

    Dans ce cas, le fold_right peut conclure plus vite (et il n'y aura aucun risque de stack overflow). C'est pour ça que la définition de or est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    or :: [Bool] -> Bool
    or = foldr (||) False
    Evidemment, pour un langage strict comme OCaml, le choix de fold_right laisse songeur...

    --
    Jedaï

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 4
    Dernier message: 15/04/2014, 11h02
  2. Réponses: 6
    Dernier message: 23/09/2010, 12h08
  3. Definir un nombre maximum dans une liste
    Par jjpopaul dans le forum Langage
    Réponses: 1
    Dernier message: 13/04/2010, 17h48
  4. Réponses: 2
    Dernier message: 17/08/2003, 21h07
  5. Réponses: 4
    Dernier message: 24/04/2003, 23h28

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo