Version française
Home     About     Download     Resources     Contact us    
Browse thread
[Caml-list] Great Beginner
[ Home ] [ Index: by date | by threads ]
[ Search: ]

[ Message by date: previous | next ] [ Message in thread: previous | next ] [ Thread: previous | next ]
Date: -- (:)
From: Diego Olivier Fernandez Pons <FernandezPons@i...>
Subject: Re: [Caml-list] Great Beginner
Je devrais peut-être cesser de poster sur ce forum, je vais réussir à
me faire plus d'ennemis que ne doit raisonnablement avoir un homme.

Le but de mon message n'était pas de dire que vous ne programmiez pas
fonctionnellement, mais d'illustrer un certain nombre de
particularités des langages fonctionnels (et que ne possèdent pas tous
langages impératifs), c'est en ce sens que j'ai dit que le code que
j'exhibais était plus « fonctionnel » ; raison pour laquelle j'ai
abordé tour à tour :
  - la définition des functions avec la syntaxe lambda
  - la récursivité ascendante et descendante
  - le pattern matching et utilisation du when
  - l'instruction trace
  - les produits cartésiens
  - les fonctions locales...

Le but en était purement pédagogique (puisque le message portait pour
titre « great beginner » et que c'était vraisemblablement le cas),
d'autant plus que vous aviez déjà illustré dans votre message
précédent les structures de contrôle « if then else » et les
références.

Votre code est bien évidemment parfaitement correct.

Moi j'écris plutôt :

let somme = function n ->
   let rec sommeCPS total = function
      | 0 -> total
      | k -> sommeCPS (total + k)  (k - 1)
   in
       sommeCPS 0 n
;;

C'est juste une question de style (d'ailleurs je ne respecte pas tout
à fait la norme Caml).

        Diego Olivier






-------------------
Bug reports: http://caml.inria.fr/bin/caml-bugs  FAQ: http://caml.inria.fr/FAQ/
To unsubscribe, mail caml-list-request@inria.fr  Archives: http://caml.inria.fr