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

Scheme Discussion :

Réécrire une fonction booléenne


Sujet :

Scheme

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    450
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 450
    Par défaut Réécrire une fonction booléenne
    Bonsoir , j'ai l'exercice suivant :

    Sans utiliser les formes spéciales and et or, ni la fonction not, écrire la fonction booléenne ou de spécification :
    ;;; ou : bool * bool -> bool
    ;;; (ou n m) rend true lorsque "n" ou "m" vaut true
    J'ai un peu de mal à saisir le sens de l'exercice , on doit faire une multiplication sur 2 types n et m et si l'un des 2 vaut true on rend true ?

    Je pense que je vais devoir utiliser des alternatives mais par exemple j'ai un code qui n'a pas de sens :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    (define (Ou n m)
      (* n m)
      (if (= n #t)
          #t
          (if (= m #t)
              #t
              #f))
      )
    Je sais que le code marche pas vu que x et y doivent etre de type nombre mais là je suis un peu perdue , si quelqu'un pouvait m'aiguiller...

    merci

  2. #2
    Membre émérite
    Avatar de GnuVince
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2004
    Messages
    679
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2004
    Messages : 679
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ;;; ou : bool * bool -> bool
    Cette notation veut dire une fonction "ou" qui prend deux arguments de types bool et qui retourne un résultat bool. Le * veut pas dire multiplication. Cette notation vient des langages ML, je suis pas sûr ce qu'elle fait dans un exercice en Scheme.

  3. #3
    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
    Citation Envoyé par GnuVince Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ;;; ou : bool * bool -> bool
    Cette notation veut dire une fonction "ou" qui prend deux arguments de types bool et qui retourne un résultat bool. Le * veut pas dire multiplication. Cette notation vient des langages ML, je suis pas sûr ce qu'elle fait dans un exercice en Scheme.
    D'un autre côté, tu peux aussi bien dire qu'elle vient directement du langage mathématique avec le * à la place de X pour des raisons de jeu de caractères : il s'agit simplement de la notation mathématique d'une fonction du produit cartésien de l'ensembles des booléens avec l'ensemble des booléens vers l'ensemble des booléens.

    Ta réaction est amusante et trahit un connaisseur des langages fonctionnels...

    --
    Jedaï

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    450
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 450
    Par défaut
    une fonction "ou" qui prend deux arguments de types bool et qui retourne un résultat bool
    justement , apparemment mon n et m sont directement considérés comme de type number , c'est peut etre du à la multiplication , et je ne vois pas comme dire que n et m sont de type bool .

  5. #5
    alex_pi
    Invité(e)
    Par défaut
    Citation Envoyé par Maxence45 Voir le message
    justement , apparemment mon n et m sont directement considérés comme de type number , c'est peut etre du à la multiplication , et je ne vois pas comme dire que n et m sont de type bool .
    la notation (bool * bool) -> bool signifie qu'on attend que tu écrives une fonction qui prend en argument deux booléen et qui retourne un booléen, il n'y a pas de multiplication. Pourquoi voudrais-tu multiplier deux booléens ?

    Et lis les réponses en partant du principes que les gens ont raison plutôt que l'inverse :-)

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    450
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 450
    Par défaut
    Et lis les réponses en partant du principes que les gens ont raison plutôt que l'inverse :-)
    tu te sens obligé de lécher les modérateurs ? lol tsss

    je préfère quitter ce forum c'est saoulant d'avoir toujours des gens pédants et lécheurs qui répondent , merci .

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

Discussions similaires

  1. Remplir 2 tableaux via une fonction booléenne filtrant sur un tableau
    Par Elvaiz dans le forum Macros et VBA Excel
    Réponses: 12
    Dernier message: 31/03/2013, 16h06
  2. Réponses: 2
    Dernier message: 18/03/2013, 13h20
  3. Réponses: 0
    Dernier message: 22/07/2009, 19h34
  4. [Turbo Pascal] Allocation et désallocation de pointeurs dans une fonction
    Par neird dans le forum Turbo Pascal
    Réponses: 13
    Dernier message: 17/11/2002, 20h14
  5. Une fonction avec des attributs non obligatoires
    Par YanK dans le forum Langage
    Réponses: 5
    Dernier message: 15/11/2002, 13h39

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