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 régulier
    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
    Points : 109
    Points
    109
    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 éminent sénior
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 199
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Février 2005
    Messages : 5 199
    Points : 12 352
    Points
    12 352
    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 sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 382
    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 382
    Points : 41 588
    Points
    41 588
    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.

  4. #4
    Membre régulier
    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
    Points : 109
    Points
    109
    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 averti 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
    Points : 395
    Points
    395
    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 éclairé

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

    Informations forums :
    Inscription : Décembre 2013
    Messages : 397
    Points : 698
    Points
    698
    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 habitué
    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
    Points : 162
    Points
    162
    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
    Expert éminent
    Avatar de Pyramidev
    Homme Profil pro
    Tech Lead
    Inscrit en
    Avril 2016
    Messages
    1 492
    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 492
    Points : 6 202
    Points
    6 202
    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 habitué
    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
    Points : 162
    Points
    162
    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, 18h23
  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, 14h31
  3. Réponses: 2
    Dernier message: 13/07/2006, 17h09

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