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 :

Nombre aléatoire type "float" entre deux bornes


Sujet :

C++

  1. #1
    Membre confirmé
    Homme Profil pro
    chercheur
    Inscrit en
    Février 2011
    Messages
    78
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : chercheur
    Secteur : Services à domicile

    Informations forums :
    Inscription : Février 2011
    Messages : 78
    Par défaut Nombre aléatoire type "float" entre deux bornes
    Bonjour,

    Est ce que vous pouvez me corriger le message d'erreur suivant : invalid operands of types ‘int’ and ‘float’ to binary ‘operator%’.
    Le code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    float borne_maximale = 0.9;
        float borne_minimale = 0.7;
        float proba[10];
        cpmt =0;
        while (cpmt<10)
        {
            proba[cpmt]=rand()%(borne_maximale - borne_minimale) + borne_minimale;
            cpmt++;
        }

    Merci d'avance.

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 461
    Par défaut
    L'opérateur % (modulo) n'existe pas sur les décimaux.
    x%0.2, cela ne veut rien dire.
    x%1.0 non plus.

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 393
    Par défaut
    double rand1_0 = rand() / (double)RAND_MAX; te donnera un nombre à virgule flottante entre 0.0 et 1.0 (diviser par (double)(RAND_MAX+1) permet d'exclure la valeur 1.0).
    À partir de ça, tu devais sans peine obtenir la plage de valeurs que tu veux.
    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.

  4. #4
    Membre confirmé
    Homme Profil pro
    chercheur
    Inscrit en
    Février 2011
    Messages
    78
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : chercheur
    Secteur : Services à domicile

    Informations forums :
    Inscription : Février 2011
    Messages : 78
    Par défaut résolu
    J'ai résolu mon problème, je vous remercie.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
       int borne_maximale = 90;
        int borne_minimale = 70;
        float proba[10];
        cpmt =0;
        while (cpmt<10)
        {
            int bigratio =rand()%(borne_maximale - borne_minimale) + borne_minimale;
            proba[cpmt] =  bigratio/100.0;
            cpmt++;
        }

  5. #5
    Membre expérimenté Avatar de RPGamer
    Homme Profil pro
    Ingénieur en systèmes embarqués
    Inscrit en
    Mars 2010
    Messages
    168
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ingénieur en systèmes embarqués

    Informations forums :
    Inscription : Mars 2010
    Messages : 168
    Par défaut
    Citation Envoyé par bacelar Voir le message
    L'opérateur % (modulo) n'existe pas sur les décimaux.
    x%0.2, cela ne veut rien dire.
    x%1.0 non plus.
    L'opérateur non mais la fonction si. Par exemple pour obtenir un angle modulo 2π, on peut faire ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    float angle = 5*M_PI/2;
    float modulo = std::fmod(angle, 2*M_PI);
    On obtient bien un angle modulo de π/2.

  6. #6
    Membre émérite

    Profil pro
    Inscrit en
    Décembre 2013
    Messages
    404
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2013
    Messages : 404
    Par défaut
    Ou std::remainder, qui est une autre facon de calculer le reste de la divison. Cf http://en.cppreference.com/w/cpp/numeric/math/remainder

  7. #7
    Membre très actif
    Homme Profil pro
    Développeur de jeux vidéo
    Inscrit en
    Mai 2014
    Messages
    227
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur de jeux vidéo
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2014
    Messages : 227
    Par défaut
    Nous sommes sur la session C++ donc rand() n'a rien à faire ici :s et le reste du code est C-style ou c++oldschool x)
    Utilise <random>
    En c++ on utilise les {} pour init donc ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    int borne_maximale = 90;
    devient ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    int borne_maximale{90};
    de plus tu devrais utilisé unsigned int qui est plus approprié
    A la place de ton while une bonne boucle for serait plus adapté :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for( size_t cmpt{0}; cmpt < 10; ++cmpt ) {}
    En c++ on utilise std::array pour les tableau statique.
    Et tes deux variables mini et maxi seront inutile car il te suffit de créer ton générateur avec une distribution :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    std::uniform_int_distribution<int> distribution(70,90);
    Bref corrige ton code pour le mettre à niveau, c'est plus propre

  8. #8
    Membre Expert
    Avatar de Pyramidev
    Homme Profil pro
    Tech Lead
    Inscrit en
    Avril 2016
    Messages
    1 512
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Tech Lead

    Informations forums :
    Inscription : Avril 2016
    Messages : 1 512
    Par défaut
    En utilisant <random>, le modèle de classe le plus approprié dans ce contexte est uniform_real_distribution :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    std::default_random_engine generator;
    std::uniform_real_distribution<float> distribution(0.7f, 0.9f);
    std::array<float, 10> proba;
    for(float& p : proba)
        p = distribution(generator);

  9. #9
    Membre très actif
    Homme Profil pro
    Développeur de jeux vidéo
    Inscrit en
    Mai 2014
    Messages
    227
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur de jeux vidéo
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2014
    Messages : 227
    Par défaut
    J'ai pas chercher plus loin il avait mi du int mais oui ce serai encore mieux de tout mettre en float par contre j'aurais laisser l'ancien for car vu le code, ça m'étonnerais qu'il utilise c++11, mais bon tant qu'a faire bien, autant le faire jusqu'au bout

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

Discussions similaires

  1. [Math / Random] Génération nombre aléatoire compris entre deux bornes
    Par oligig dans le forum Collection et Stream
    Réponses: 5
    Dernier message: 30/06/2013, 17h23
  2. Générer un nombre entier aléatoire entre deux bornes
    Par zozoman dans le forum Débuter
    Réponses: 6
    Dernier message: 28/02/2012, 13h31
  3. Réponses: 2
    Dernier message: 13/07/2006, 16h09

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