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

Python Discussion :

trouver un entier max dans une liste


Sujet :

Python

  1. #1
    Membre à l'essai
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Septembre 2018
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Septembre 2018
    Messages : 27
    Points : 20
    Points
    20
    Par défaut trouver un entier max dans une liste
    Bonjour,

    Je voudrais comprendre un code ci-dessous qui permet d'afficher un entier maximum et l'indice de cet entier.

    Je crois que i est compteur qui parcourt la liste. Pourquoi on a besoin aussi de "a" qui est aussi un compteur, je crois ? Pourtant, si on ne donne pas ce compteur a, quand je returne le compteur i, j'obtiens l'indice 6, au lieu de 1 qui est l'indice de l'entrier maxi. Je vous remercie de votre aide.


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    def idx_max(liste):
    	max = liste[0]
    	a = 0  # a est un compteur ??
    	for i in range(len(liste)):
    		if liste[i] > max:
    			max  = liste [i]
    			a = i
    	return max, a 
     
    s = [6, 2456, 3, 33, 6, 88, 10]
    print (idx_max(s))

  2. #2
    Membre averti Avatar de zancrows
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2016
    Messages
    155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2016
    Messages : 155
    Points : 346
    Points
    346
    Par défaut
    Bonjour,

    on a besoin de a pour garder en mémoire l'indice est le retourner ensuite, en somme garder en mémoire i quand on la valeur de liste[i] est plus grande que la variable max.

    Sinon utiliser enumerate est plus pratique pour récupérer l'indice et la valeur

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    for i, v in enumerate(range(10,20)):
        print(f"indice: {i}, val:{v}")

  3. #3
    Membre chevronné
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2013
    Messages
    1 608
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 608
    Points : 2 072
    Points
    2 072
    Par défaut
    On peut s'en passer.
    Par contre, la variable max n'est pas très heureux
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    def idx_max(liste):
        maxi = liste[0]
        for i in range(len(liste)):
            if liste[i] > maxi:
                maxi  = liste [i]
        return maxi, i
     
    s = [6, 2456, 3, 33, 6, 88, 10]
    print (idx_max(s))
    Pas d'aide par mp.

  4. #4
    Membre émérite

    Homme Profil pro
    Ingénieur calcul scientifique
    Inscrit en
    Mars 2013
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur calcul scientifique

    Informations forums :
    Inscription : Mars 2013
    Messages : 1 229
    Points : 2 328
    Points
    2 328
    Par défaut
    @marco : cela m'étonnerait que ton code fonctionne correctement. A la fin de la boucle for, i vaut nécéssairement len(liste). Et je doute fort que ce soit l'indice du maximum ...

    Il n'y a pas le choix, il faut passer par une variable intermédiaire, qui va garder en mémoire les mises à jour successives, sachant que la dernière mis à jour n'est pas nécésséraiment (et même dans la plupart des cas, n'est pas) réalisée lors de la dernière itération

  5. #5
    Membre averti Avatar de zancrows
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2016
    Messages
    155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2016
    Messages : 155
    Points : 346
    Points
    346
    Par défaut
    Citation Envoyé par marco056 Voir le message
    On peut s'en passer.
    Par contre, la variable max n'est pas très heureux
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    def idx_max(liste):
        maxi = liste[0]
        for i in range(len(liste)):
            if liste[i] > maxi:
                maxi  = liste [i]
        return maxi, i
     
    s = [6, 2456, 3, 33, 6, 88, 10]
    print (idx_max(s))
    l'exemple que tu montres ne donne pas l'indice du max vu que tu parcours toute la liste avant le return, il retourne juste l'indice du dernier élément de la liste

    edit: devancé par lg_53

    sinon on peut passer par max et index

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    def idx_max(liste):
        maxi = max(liste)
        i = liste.index(maxi)
     
        return maxi, i
     
    s = [6, 33, 2456, 3, 33, 6, 88, 10]
    print (idx_max(s))

  6. #6
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    Salut,

    Heum, à mon avis l'OP doit faire un exercice sans max et index, sinon il n'y a plus d'exercice.

    On peut aussi itérer directement sur les valeurs:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    def idx_max(liste):
        c = 0
        max_ = liste[0], c
        for i in liste:
            if i > max_[0]:
                max_ = i, c
            c += 1
        return max_

  7. #7
    Membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mars 2013
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2013
    Messages : 25
    Points : 45
    Points
    45
    Par défaut
    index et max sont des fonctions natives python (built-in)

    L'index dans la liste :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    liste.index(max(liste))
    et le max de la liste :

  8. #8
    Membre chevronné
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2013
    Messages
    1 608
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 608
    Points : 2 072
    Points
    2 072
    Par défaut
    Citation Envoyé par lg_53 Voir le message
    @marco : cela m'étonnerait que ton code fonctionne correctement. A la fin de la boucle for, i vaut nécéssairement len(liste). Et je doute fort que ce soit l'indice du maximum ...

    Il n'y a pas le choix, il faut passer par une variable intermédiaire, qui va garder en mémoire les mises à jour successives, sachant que la dernière mis à jour n'est pas nécésséraiment (et même dans la plupart des cas, n'est pas) réalisée lors de la dernière itération
    Oups !
    Oui, je suis allé un peu vite...
    Désolé pour l'erreur du coup.
    Pas d'aide par mp.

  9. #9
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 684
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 684
    Points : 30 973
    Points
    30 973
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par lucie34 Voir le message
    Je crois que i est compteur qui parcourt la liste. Pourquoi on a besoin aussi de "a" qui est aussi un compteur, je crois ?
    Un compteur ça compte or "a" ne compte rien. Il est positionné quand une condition est atteinte. Donc il sert à mémoriser un évènement (ou une valeur) qui était présente lorsque la condition a été atteinte.

    Citation Envoyé par lucie34 Voir le message
    Pourtant, si on ne donne pas ce compteur a, quand je returne le compteur i, j'obtiens l'indice 6, au lieu de 1 qui est l'indice de l'entrier maxi.
    Ben oui. Sans déconner, je ne pige rien à la façon dont fonctionne ta cervelle. "i" sert à itérer sur les éléments de la liste. Donc en fin de boucle, il a fatalement la valeur du dernier indice traité !!! Mais ce dernier indice n'est pas forcément celui de la plus grande valeur de ta liste...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

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

Discussions similaires

  1. Réponses: 8
    Dernier message: 18/12/2015, 14h29
  2. trouver le max dans une liste
    Par peterpan3000 dans le forum Général Python
    Réponses: 4
    Dernier message: 08/01/2015, 10h35
  3. Trouver valeur d'encadrement dans une liste
    Par diego45 dans le forum MATLAB
    Réponses: 4
    Dernier message: 22/09/2014, 16h55
  4. Fonction récursive trouver le max dans une liste.
    Par shirohige dans le forum Lisp
    Réponses: 17
    Dernier message: 17/09/2014, 19h54
  5. Trouver l'index courant dans une liste
    Par Hepil dans le forum C#
    Réponses: 5
    Dernier message: 27/09/2010, 12h25

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