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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Avril 2009
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 40
    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
    Membre averti
    Inscrit en
    Avril 2009
    Messages
    40
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 40
    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 confirmé
    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
    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 confirmé
    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
    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ï

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

Discussions similaires

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

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