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

C++ Discussion :

question en C++


Sujet :

C++

  1. #1
    Nouveau membre du Club
    Inscrit en
    Mars 2004
    Messages
    51
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 51
    Points : 34
    Points
    34
    Par défaut question en C++
    dans un test d'embauche on m'a posé la question suivante :

    comment tester si un nombre est divisible par 3 ou par 5 ou n'importe quel autre nombre sans utiliser la fonction modulo

    donc j'ai pas trouvé la réponse et je demande votre aide

    Merci d'avance

  2. #2
    Expert éminent sénior
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 275
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2003
    Messages : 5 275
    Points : 10 985
    Points
    10 985
    Par défaut
    Ben ...tu implémentes le modulo (aka reste de la division entière) à la main.
    Blog|FAQ C++|FAQ fclc++|FAQ Comeau|FAQ C++lite|FAQ BS|Bons livres sur le C++
    Les MP ne sont pas une hotline. Je ne réponds à aucune question technique par le biais de ce média. Et de toutes façons, ma BAL sur dvpz est pleine...

  3. #3
    Nouveau membre du Club
    Inscrit en
    Mars 2004
    Messages
    51
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 51
    Points : 34
    Points
    34
    Par défaut
    comment l'implémenter avec du code C++

  4. #4
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    tu prends ton diviseur potentiel (3 ou 5 ou autre) et tu l'ajoutes plein de fois à un compteur jusqu'à être égal ou supérieur au nombre à tester. Si tu es égal, c'est que le nombre est un multiple de ton fameux diviseur, donc il est divisible par lui. Si tu es supérieur, c'est le contraire...

    Bien sûr, c'est lent (pour les amateurs de théorie de la complexité, ça doit se faire en temps exponentiel (en considérant la taille du nombre et non le nombre lui-même)). Mais ça devrait marcher.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  5. #5
    zul
    zul est déconnecté
    Membre éclairé Avatar de zul
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    498
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 498
    Points : 699
    Points
    699
    Par défaut
    si ton nombre est un entier, tu peux faire ca :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    int a = 478;
    int b = a / 3;
    return  ( (b *  3) == a );

  6. #6
    Membre expert
    Avatar de trotters213
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2 571
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Gard (Languedoc Roussillon)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 571
    Points : 3 145
    Points
    3 145
    Par défaut

    C'est pas plus simple en faisant de la redéfinition d'opérateur? C'est à dire un truc du style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    int taClasse :: operator % (const int & diviseur , const int & dividende)
    {
       int i=0;
       while ((i+1)*diviseur<dividende) i++;
       return  (dividende - i*diviseur);
    }
    Comme ça si tu le réutilises plusieurs fois, tu n'utilise plus que l'opérateur %.

  7. #7
    Nouveau membre du Club
    Inscrit en
    Mars 2004
    Messages
    51
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 51
    Points : 34
    Points
    34
    Par défaut
    Citation Envoyé par Médinoc
    tu prends ton diviseur potentiel (3 ou 5 ou autre) et tu l'ajoutes plein de fois à un compteur jusqu'à être égal ou supérieur au nombre à tester. Si tu es égal, c'est que le nombre est un multiple de ton fameux diviseur, donc il est divisible par lui. Si tu es supérieur, c'est le contraire...

    Bien sûr, c'est lent (pour les amateurs de théorie de la complexité, ça doit se faire en temps exponentiel (en considérant la taille du nombre et non le nombre lui-même)). Mais ça devrait marcher.

    Merci beaucoup très bonne idée

  8. #8
    Expert éminent sénior

    Homme Profil pro
    pdg
    Inscrit en
    Juin 2003
    Messages
    5 751
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : pdg

    Informations forums :
    Inscription : Juin 2003
    Messages : 5 751
    Points : 10 667
    Points
    10 667
    Billets dans le blog
    3
    Par défaut
    Pour info, tu as combien de temps pour répondre à cette question ?
    Sinon je propose un petit template basé sur la solution de zul:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    template<int Div>
    bool IsDivisibleBy( int Value )
    {
        int a = Value / Div; 
        return  (a *  Div) == Value; 
    }
     
    IsDivisibleBy<5>( 10 );
    IsDivisibleBy<3>( 10 ) ;

  9. #9
    Nouveau membre du Club
    Inscrit en
    Mars 2004
    Messages
    51
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 51
    Points : 34
    Points
    34
    Par défaut
    Merci bcp à tout le monde

  10. #10
    Expert éminent sénior
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 275
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2003
    Messages : 5 275
    Points : 10 985
    Points
    10 985
    Par défaut
    Citation Envoyé par 79Charles
    Citation Envoyé par Médinoc
    tu prends ton diviseur potentiel (3 ou 5 ou autre) et tu l'ajoutes plein de fois à un compteur jusqu'à être égal ou supérieur au nombre à tester. Si tu es égal, c'est que le nombre est un multiple de ton fameux diviseur, donc il est divisible par lui. Si tu es supérieur, c'est le contraire...

    Bien sûr, c'est lent (pour les amateurs de théorie de la complexité, ça doit se faire en temps exponentiel (en considérant la taille du nombre et non le nombre lui-même)). Mais ça devrait marcher.
    Merci beaucoup très bonne idée

    Médinoc devait te faire une blague...
    J'avoue que je ne poserai pas de telles questions. Mais tout de même! Pas ça en entretien La définition du modulo est mathématiquement très simple. Une solution itérative n'a d'autre intérêt que de figurer au dailywtf ou autre OCCC. Il faut faire simple.
    Blog|FAQ C++|FAQ fclc++|FAQ Comeau|FAQ C++lite|FAQ BS|Bons livres sur le C++
    Les MP ne sont pas une hotline. Je ne réponds à aucune question technique par le biais de ce média. Et de toutes façons, ma BAL sur dvpz est pleine...

  11. #11
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    En fait, honte sur moi, je ne blaguais même pas... Après le ban du modulo, j'avais complètement zappé le fait que la division entière "normale" pouvait toujours être utilisée... (Et pourtant, rétrospectivement, je me souviens l'avoir déjà fait)

    Et depus que j'ai bu la bonne solution, je n'en reviens pas que quelqu'un d'autre que moi ait pu trouver l'idée bonne...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  12. #12
    Expert éminent sénior
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 275
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2003
    Messages : 5 275
    Points : 10 985
    Points
    10 985
    Par défaut

    Citation Envoyé par Médinoc
    (Et pourtant, rétrospectivement, je me souviens l'avoir déjà fait)
    Je le refais parfois dans des langages de script qui ne disposent pas du modulo, voire avec ma petite calculette quand j'essaie de comprendre pourquoi ma télémétrie n'est pas en face des trous.
    Blog|FAQ C++|FAQ fclc++|FAQ Comeau|FAQ C++lite|FAQ BS|Bons livres sur le C++
    Les MP ne sont pas une hotline. Je ne réponds à aucune question technique par le biais de ce média. Et de toutes façons, ma BAL sur dvpz est pleine...

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 11/08/2002, 21h27
  2. Divers questions
    Par Freakazoid dans le forum DirectX
    Réponses: 2
    Dernier message: 06/08/2002, 21h57
  3. question sur les message box !
    Par krown dans le forum Langage
    Réponses: 7
    Dernier message: 02/08/2002, 16h11
  4. Question de faisabilité
    Par lisarasu dans le forum CORBA
    Réponses: 3
    Dernier message: 14/05/2002, 11h26
  5. [HyperFile] 2 questions de débutant
    Par khan dans le forum HyperFileSQL
    Réponses: 2
    Dernier message: 29/04/2002, 23h18

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