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

Langage PHP Discussion :

Boucle for pour chercher min et max


Sujet :

Langage PHP

  1. #1
    Futur Membre du Club
    Inscrit en
    Janvier 2011
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Janvier 2011
    Messages : 9
    Points : 8
    Points
    8
    Par défaut Boucle for pour chercher min et max
    Bonsoir

    Je patauge un peu avec mes boucle for.

    Mon but est de rechercher la plus grande et la plus petite valeur d'un tableau nommé : $InfosEleve

    La boucle for doit chercher dans :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $InfosEleve[0]['RCO_MoyenneEleve'] = '7';
    $InfosEleve[1]['RCO_MoyenneEleve'] = '11.5';
    (il y'a 6 élèves) ; idem pour la valeur maximum

    Merci par avance pour vos propositions

  2. #2
    Membre éprouvé
    Avatar de amoiraud
    Homme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2006
    Messages
    606
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2006
    Messages : 606
    Points : 1 057
    Points
    1 057
    Par défaut
    Salut,
    Tu peut faire comme ca :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    $noteMin = 20;
    $noteMax = 0;
    foreach ($i = 0; $i <= sizeof($InfosEleve) - 1; $i++) {
      if ($InfosEleve[$i]['RCO_MoyenneEleve'] < $noteMin) {
        $noteMin = $InfosEleve[$i]['RCO_MoyenneEleve'];
      }
      if ($InfosEleve[$i]['RCO_MoyenneEleve'] > $noteMax) {
        $noteMax = $InfosEleve[$i]['RCO_MoyenneEleve'];
      }
    }

  3. #3
    Expert éminent
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Points : 7 762
    Points
    7 762
    Par défaut
    amoiraud, je crois que tu as mis les bornes à l'envers

    En optimisant un peu ça donne:
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    $k = array_keys($InfosEleve);
    $c = count($k);
    for ($i = 0; $i < $c; $i++) {
      if (!isset($noteMin) && !isset($noteMax)) {
        $noteMin = $noteMax = $InfosEleve[$k[$i]]['RCO_MoyenneEleve'];
      }
      if ($InfosEleve[$k[$i]]['RCO_MoyenneEleve'] < $noteMin) {
        $noteMin = $InfosEleve[$k[$i]]['RCO_MoyenneEleve'];
      }
      if ($InfosEleve[$k[$i]]['RCO_MoyenneEleve'] > $noteMax) {
        $noteMax = $InfosEleve[$k[$i]]['RCO_MoyenneEleve'];
      }
    }

    On peut aussi imaginer ça (faire un bench pour savoir qui est le plus performant):
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    foreach ($InfosEleve as $info) {
      $r[] = $info['RCO_MoyenneEleve'];
    }
    $min = min($r);
    $max = max($r);

    Enfin, si les données provennent d'une DB, tu peux utiliser min et max: http://dev.mysql.com/doc/refman/5.0/...functions.html

  4. #4
    Membre éprouvé
    Avatar de amoiraud
    Homme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2006
    Messages
    606
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2006
    Messages : 606
    Points : 1 057
    Points
    1 057
    Par défaut
    Citation Envoyé par Benjamin Delespierre Voir le message
    amoiraud, je crois que tu as mis les bornes à l'envers
    Heu... effectivement, on mettra ca sur le compte de la fatigue et des 3 heures que j'ai passé sur une requête cet aprem au taf

    romcollard utilise le code de Benjamin

Discussions similaires

  1. Réponses: 1
    Dernier message: 18/02/2008, 19h21
  2. création d'une boucle for pour interrogation requête sql
    Par philder62 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 10/12/2007, 15h14
  3. Réponses: 7
    Dernier message: 10/10/2007, 19h23
  4. Comparaison de trois variables pour trouver min et max
    Par Wylwaryn dans le forum Assembleur
    Réponses: 1
    Dernier message: 19/03/2007, 10h20
  5. Réponses: 2
    Dernier message: 29/08/2006, 13h59

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