Partage
  • Partager sur Facebook
  • Partager sur Twitter

exo python liste

    26 novembre 2019 à 16:27:42

    Alors voilà j'ai un exo à faire pour demain en python mais je le trouve plutot compliqué, si quelqu'un peut m'aider j'en serai ravi.

    Voilà, merci.

    Voici le lien de l'exo https://drive.google.com/file/d/17dAg7NqdwqEynLMFu6UvNwIGnip4_0sA/view?usp=sharing

    -
    Edité par AbcAbc6 26 novembre 2019 à 18:09:20

    • Partager sur Facebook
    • Partager sur Twitter
      26 novembre 2019 à 16:37:57

      Pour le premier deux solutions :

      - Chercher l'indice du plus grand nombre de ton tableau, et afficher le lieux de ce meme indice

      - Utiliser un dictionnaire, auquel tu associe chaque points de ton tableau (key) a son altitude (value), et tu fais demande d'afficher la key correspondant a la plus grande value.

      Pour le second tu parcours simplement ton tableau case par case, et si la case precedente est plus grande que la suivante, tu ajoutes 1 a ta reponse.

      -
      Edité par HugoCarpentier1 26 novembre 2019 à 16:39:43

      • Partager sur Facebook
      • Partager sur Twitter
        26 novembre 2019 à 16:41:00

        Bonjour,

        Le message qui suit est une réponse automatique activée par un membre de l'équipe. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention.
        Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé.

        Pour plus d'informations, nous vous invitons à lire les règles générales du forum

        Manque de Politesse

        Votre message ne comporte pas ou peu de formules de politesse (« Bonjour », « Merci », « Au revoir », etc.). Les règles du site exigent que chaque nouveau message comporte un minimum de politesse. Après tout, les gens qui répondent le font gratuitement, sur leur temps libre. Ils méritent bien un minimum de considération, n'est-ce pas ?

        Mauvais titre

        Le titre est un élément important qui ne doit pas être négligé. N'oubliez pas cette règle simple : le titre idéal résume la question que vous allez poser en une petite phrase. Il doit permettre aux visiteurs de se repérer facilement dans le forum visité et d'identifier le sujet à sa seule lecture.

        Vous pouvez utiliser divers préfixes comme [Erreur], [MySQL], [Compatibilité], etc... Aussi, pensez à consulter les règles propres à chaque forum (visibles dans les topics épinglés en haut des sections).

        De plus, choisir un bon titre permet de rendre plus faciles les recherches des autres membres.

        Les titres de type "besoin d'aide" ou "problème" ne sont pas tolérés.

        Pour modifier votre titre, éditez le premier message de votre sujet.

        (titre originel : Besoin d'aide)

        Liens conseillés

        • Partager sur Facebook
        • Partager sur Twitter
          26 novembre 2019 à 17:10:18

          HugoCarpentier1 a écrit:

          Pour le premier deux solutions :

          - Chercher l'indice du plus grand nombre de ton tableau, et afficher le lieux de ce meme indice

          - Utiliser un dictionnaire, auquel tu associe chaque points de ton tableau (key) a son altitude (value), et tu fais demande d'afficher la key correspondant a la plus grande value.

          Pour le second tu parcours simplement ton tableau case par case, et si la case precedente est plus grande que la suivante, tu ajoutes 1 a ta reponse.

          -
          Edité par HugoCarpentier1 il y a 28 minutes

          Ok merci j'essai



          • Partager sur Facebook
          • Partager sur Twitter
            26 novembre 2019 à 17:16:27

            Puisque tu as l'air presse, voici la solution, essaie quand meme de t'y prendre plus tot la prochaine fois ^^' :

            def plushaut(p, a):
                tampon = 0 # indice du lieu le plus haut
                for i in range(1, len(a)): # on commence a 1 un puisqu'on a deja tampon = 0
                    if a[i] > a[tampon]: # si la nouvelle altitude est plus grande que l'altitude tampon
                        tampon = i # alors elle devient la nouvelle plus haute altitude
                return p[tampon] # on retourne le nom correspondant a l'altitude
                
            def nbdescentes(a):
                tampon = a[0] # On commence par prendre la premiere altitude
                compteur = 0 # Le nombre de descente
                for i in a[1:]: # on commence a a[1] un puisqu'on a deja tampon = a[0]
                    if i < tampon: # si la nouvelle altitude est plus petite que l'altitude tampon
                        compteur +=1 # on ajoute une descente
                    tampon = i # dans tous les les cas on prend la derniere altitude analysee comme nouvelle reference
                return compteur # on retourne le nombre de descente
            
            points = ["Verviers", "Côte de Sart", 'Stavelot', "Trois-Ponts", "Vielsalm", "Troisvierges","Wincrange","Wiltz", "Côte de Wiltz", "Côte d'Eschdorf", "Saeul", "Dippach", "Esch-sur-Aizette", "Côte de Villers-la-Montagne", "Côte des religieuses"]
            altitudes = [212,543,317,251,361,479,504,319,467,499,294,370,321,414,379]
            
            print(plushaut(points, altitudes))
            print(nbdescentes(altitudes))
            



            • Partager sur Facebook
            • Partager sur Twitter
              26 novembre 2019 à 17:16:43

              @kaisbussiere Bonjour, mon message plus haut n'est pas la pour faire joli, merci de respecter les règles du forum en éditant votre premier message affin d'en changer le titre. Dans le cas contraire je serais contrains de fermer ce sujet.

              • Partager sur Facebook
              • Partager sur Twitter
                26 novembre 2019 à 18:02:23

                HugoCarpentier1 a écrit:

                Puisque tu as l'air presse, voici la solution, essaie quand meme de t'y prendre plus tot la prochaine fois ^^' :

                def plushaut(p, a):
                    tampon = 0 # indice du lieu le plus haut
                    for i in range(1, len(a)): # on commence a 1 un puisqu'on a deja tampon = 0
                        if a[i] > a[tampon]: # si la nouvelle altitude est plus grande que l'altitude tampon
                            tampon = i # alors elle devient la nouvelle plus haute altitude
                    return p[tampon] # on retourne le nom correspondant a l'altitude
                    
                def nbdescentes(a):
                    tampon = a[0] # On commence par prendre la premiere altitude
                    compteur = 0 # Le nombre de descente
                    for i in a[1:]: # on commence a a[1] un puisqu'on a deja tampon = a[0]
                        if i < tampon: # si la nouvelle altitude est plus petite que l'altitude tampon
                            compteur +=1 # on ajoute une descente
                        tampon = i # dans tous les les cas on prend la derniere altitude analysee comme nouvelle reference
                    return compteur # on retourne le nombre de descente
                
                points = ["Verviers", "Côte de Sart", 'Stavelot', "Trois-Ponts", "Vielsalm", "Troisvierges","Wincrange","Wiltz", "Côte de Wiltz", "Côte d'Eschdorf", "Saeul", "Dippach", "Esch-sur-Aizette", "Côte de Villers-la-Montagne", "Côte des religieuses"]
                altitudes = [212,543,317,251,361,479,504,319,467,499,294,370,321,414,379]
                
                print(plushaut(points, altitudes))
                print(nbdescentes(altitudes))
                



                Je te remercie énormément ! Voilà quand meme ce que j'avais essayé de faire pour le premier (ça marche pas). Je suis un grand débutant sur python donc voilà.

                def plushaut(p,a):
                    n=len(a)
                    for element in range(n):
                        max(a)=x
                        x=a.index(x)
                    print(p[x])
                       

                Et oui, la prochaine fois je m'y prendrai plus tot. Encore Merci !

                -
                Edité par Kaïs__ 26 novembre 2019 à 18:05:19

                • Partager sur Facebook
                • Partager sur Twitter
                  27 novembre 2019 à 9:50:32

                  Pas de soucis content d'avoior pu aider :).

                  Juste pour que tu saches ce que tu avais fait :

                  n = longueur de ta liste a

                  pour chaque Element compris entre 0 et n :

                  retourn du maximum de a, puis = x ( je ne vois pas comment mieux le dire, en soit ca n'a pas de sens ^^').

                  x devient un l'index du premier element valant x

                  affciher l'element correspondant dans la liste p.

                  Si tu veux garder ta logiaue (que je crois comprendre), tu pouvais faire :

                  def plushaut(p,a):
                      x = max(a)
                      x = a.index(x)
                      return p[x]

                  Qui est je l'admet bien plus court, mais comme tu debutes j'ai prefere te donner une solution plus "algorithmique", plutot que celle ci qui repose sur des fonctions de python.

                  Comme tu vois la fonction max renvoie le maximum de a, c'est donc inutile de boucler ^^.

                  • Partager sur Facebook
                  • Partager sur Twitter

                  exo python liste

                  × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
                  × Attention, ce sujet est très ancien. Le déterrer n'est pas forcément approprié. Nous te conseillons de créer un nouveau sujet pour poser ta question.
                  • Editeur
                  • Markdown