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 :

code pour ordonnerTableau n'est pas façile..


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    103
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 103
    Par défaut code pour ordonnerTableau n'est pas façile..
    Bonjour, oups tromper de forum



    Je ne comprends pas les instructions de la fonction ordonnerTableau


    Pouvez vous me commenter en détail si possible cette fonction ordonnerTableau?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    int main(int argc, char *argv[])
    {
        long tableau[10] = {2, 4, 3, 1, 15, 6, 9, 16, 19, 12};
        long i = 0;
     
        ordonnerTableau(tableau, 10);
     
        for(i = 0; i < 10; i++)
        {
            printf("%ld\n", tableau[i]);
        }
     
        return 0;
    }
     
     
    void ordonnerTableau(long tableau[], long tailleTableau)
    {
        long i = 0, j = 0, a = 0;
     
        for(j = 0; j < tailleTableau-1; j++)
        {
            for(i = 0; i < tailleTableau-1; i++)
            {
                if(tableau[i] > tableau[i+1])
                {
                    a = tableau[i+1];
                    tableau[i+1] = tableau[i];
                    tableau[i] = a;
                }
            }
        }
    }

  2. #2
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Chercheur d'emploi
    Inscrit en
    Septembre 2007
    Messages
    7 487
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Chercheur d'emploi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 487
    Par défaut
    C'est une fonction censée trier ton tableau par ordre croissant, mais qui est intrinsèquement buguée et notoirement inefficace. Sa complexité est en O(n²).

    D'abord, la boucle intérieure « i » compare chaque élément du tableau avec le suivant et les permute si le premier est supérieur au second. Seulement, en scannant toutes les positions, l'élément [i+1] se retrouve en dehors du tableau. Et s'il y a permutation, il risque d'y avoir corruption de la pile et tu vas te retrouver avec une belle segfault sans comprendre d'où elle vient.

    Ensuite, le tableau n'est pas encore trié à ce stade : lorsque l'on permute deux chiffres, on ne sait pas si le plus petit n'est pas encore inférieur à un autre chiffre que l'on a déjà classé. Ton programme refait donc une passe. C'est le rôle de la boucle j. Comme, dans l'absolu, un nombre ne peut pas se déplacer plus de n fois, dans le cas où le plus petit nombre serait à la fin de ton tableau et qu'il remonterait, position par position, jusqu'à son début, on sait qu'en faisant n passes, le tableau sera forcément trié.

    Sauf qu'avec 10 éléments, ça passe, mais avec un million d'éléments, et en considérant très largement que tu sois capable de permuter un million d'éléments par seconde, il te faudrait onze jours pour en venir à bout.


    C'est à rendre pour quand ?

  3. #3
    Membre émérite
    Avatar de Pouet_forever
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    671
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 671
    Par défaut
    Citation Envoyé par Obsidian Voir le message
    Seulement, en scannant toutes les positions, l'élément [i+1] se retrouve en dehors du tableau. Et s'il y a permutation, il risque d'y avoir corruption de la pile et tu vas te retrouver avec une belle segfault sans comprendre d'où elle vient.
    Je pense que la fonction est correcte à ce niveau là. En effet, la variable va de i à 'tailleTableau-1' -1 donc il n'y a pas de dépassement.
    Bon, il n'en est rien que je n'aime pas trop cette implémentation.

  4. #4
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Chercheur d'emploi
    Inscrit en
    Septembre 2007
    Messages
    7 487
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Chercheur d'emploi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 487
    Par défaut
    Si, si, regarde bien.

    La fonction reçoit « 10 » en argument, soit la taille déclarée du tableau. Ensuite, « i » comme « j » courent bien de 0 à « tailleTableau-1 ». La cellule « tailleTableau-1 » est donc la dernière du tableau (les dix cellules sont numérotées de 0 à 9).

    Comme, à l'intérieur de la boucle, on compare tableau[i] à tableau[i+1], il y aura bien un dépassement.

  5. #5
    Membre émérite
    Avatar de Pouet_forever
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    671
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 671
    Par défaut
    Non, justement elles vont de 0 à tailleTableau-2 (à cause du < ). Donc le i+1 ne fait pas de dépassement.
    J'ai mis un coup de débuggeur pour être sûr de ce que je dis.

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    103
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 103
    Par défaut
    Merci a vous, c'est plus clair..

    Le -1 de la boucle for (i = 0; i < tailleTableau-1; i++) sert a ne pas sortir du tableau car cette boucle parcourt le tableau.

    Mais le -1 de la boucle for (j = 0; j < tailleTableau-1; j++) ne sert a rien car cette boucle ne parcourt pas le tableau met permet de répéter la 1ere boucle.. Alors pourquoi mettre le -1?


    Merci

  7. #7
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Chercheur d'emploi
    Inscrit en
    Septembre 2007
    Messages
    7 487
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Chercheur d'emploi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 487
    Par défaut
    Citation Envoyé par Pouet_forever Voir le message
    Non, justement elles vont de 0 à tailleTableau-2 (à cause du < ). Donc le i+1 ne fait pas de dépassement.
    J'ai mis un coup de débuggeur pour être sûr de ce que je dis.
    Je m'incline ! C'est toi qui a raison, malgré deux relectures. Il faudra que je songe à poster plus tôt.

Discussions similaires

  1. [XE7-Indy] Erreur code de réponse n'est pas valide
    Par mario9 dans le forum Langage
    Réponses: 3
    Dernier message: 19/02/2015, 16h23
  2. Réponses: 1
    Dernier message: 02/02/2015, 16h31
  3. [MySQL] mon code en sql n'est pas pris en compte après un ">"
    Par boxster77 dans le forum PHP & Base de données
    Réponses: 16
    Dernier message: 30/11/2010, 14h58
  4. Réponses: 2
    Dernier message: 28/11/2007, 14h34

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