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 :

Problème d'affichage lors du changement de taille


Sujet :

C

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2019
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2019
    Messages : 43
    Points : 38
    Points
    38
    Par défaut Problème d'affichage lors du changement de taille
    Bonsoir,
    Je travaille actuellement sur le rangement des valeurs d'un tableau dans l'ordre croissant. Jusque là aucun problème par contre quand j (nombre de valeurs du tableau) est supérieur à 5 le programme ne s'exécute pas correctement. Quelqu'un pourrait il m'aider svp? Merci!
    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
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
     
    #include <stdio.h>
    #include <stdlib.h>
    void ordrecroissant(long int*, long int);
    int main()
    {
        long int i=0, j=0;
        long int tableau[i];
        printf("Entrer le nombre de valeurs du tableau:\n");
        scanf("%d", &j);
        printf("Entrez les differentes valeurs du tableau:\n");
     
         for(i=0; i<j; i++)
        {
        scanf("%d", &tableau[i]);
        }
     
        ordrecroissant(tableau, j);
     
        printf("Les valeurs du tableau sont:\n");
         for(i=0; i<j; i++)
        {
        printf("%d \n", tableau[i]);
        }
     
     
        return 0;
    }
     
    void ordrecroissant(long int tableau[], long int taille)
    {
        long int i=0,x=0, n=0;
     
        for(i=0;i<taille;i++)
        {
            for(n=i;n<taille;n++)
            {
     
                    if(tableau[i]>tableau[n])
                    {
                        x=tableau[i];
                        tableau[i]=tableau[n];
                        tableau[n]=x;
                    }
     
     
     
     
            }
        }
    }

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Network game programmer
    Inscrit en
    Juin 2010
    Messages
    7 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Canada

    Informations professionnelles :
    Activité : Network game programmer

    Informations forums :
    Inscription : Juin 2010
    Messages : 7 115
    Points : 32 967
    Points
    32 967
    Billets dans le blog
    4
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    long int i=0, j=0;
        long int tableau[i];
    En plus d'être un VLA, ce qui n'est pas toujours permis, la taille est 0. Donc un tableau de taille 0. Tu risques pas d'y ranger beaucoup d'entrées.
    Pensez à consulter la FAQ ou les cours et tutoriels de la section C++.
    Un peu de programmation réseau ?
    Aucune aide via MP ne sera dispensée. Merci d'utiliser les forums prévus à cet effet.

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2019
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2019
    Messages : 43
    Points : 38
    Points
    38
    Par défaut
    J'avais vraiment pas fait attention à cette bêtise J'éviterai cela à l'avenir promis! Merci de votre aide!

    Citation Envoyé par Bousk Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    long int i=0, j=0;
        long int tableau[i];
    En plus d'être un VLA, ce qui n'est pas toujours permis, la taille est 0. Donc un tableau de taille 0. Tu risques pas d'y ranger beaucoup d'entrées.
    Pardon mais qu'est ce qu'une VLA?

  4. #4
    Expert confirmé
    Inscrit en
    Mars 2005
    Messages
    1 431
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 1 431
    Points : 4 182
    Points
    4 182
    Par défaut
    Variable-length array : un tableau dont la taille n'est pas encore connue à la compilation, et donc déterminée à l'exécution par la valeur d'un paramètre runtime. En gros, une allocation dynamique sur la pile (plutôt que sur le tas).

  5. #5
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    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 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Fvb02 Voir le message
    Pardon mais qu'est ce qu'une VLA?
    C'est pas toujours permis car outre le fait que c'est un truc récent (donc pas forcément connu par tous les compilateurs), il n'y a aucun mécanisme de détection d'erreur. Si le tableau peut pas être créé, tu n'as rien qui te le dit et tu ne peux rien faire (comme programmer une procédure de secours ou autre)
    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]

  6. #6
    Responsable Systèmes


    Homme Profil pro
    Gestion de parcs informatique
    Inscrit en
    Août 2011
    Messages
    17 451
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Gestion de parcs informatique
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Août 2011
    Messages : 17 451
    Points : 43 097
    Points
    43 097
    Par défaut
    On peut aussi se demander pourquoi ça marche jusqu'à 5.

    Tu te retrouves dans une situation ou tu ne réserves pas la place mémoire nécessaire au bon fonctionnement de ton programme. Le compilateur ne connait pas la valeur de i lors de la déclaration (voir les explications précédentes) et n'a donc aucun moyen de réserver la mémoire qu'il te faut.

    Tu as un fonctionnement jusqu'à 5 car quand une allocation mémoire est faite, la mémoire réservée peut être un peu supérieure à ce que tu as demandé (alignement mémoire notamment). Le code, tout en étant faux, peut donc fonctionner avec quelques octets de plus utilisés qui débordent de la zone normalement réservée, mais dès que tu dépasses le seuil : .
    Ma page sur developpez.com : http://chrtophe.developpez.com/ (avec mes articles)
    Mon article sur le P2V, mon article sur le cloud
    Consultez nos FAQ : Windows, Linux, Virtualisation

  7. #7
    Membre confirmé
    Homme Profil pro
    amateur
    Inscrit en
    Octobre 2007
    Messages
    731
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur

    Informations forums :
    Inscription : Octobre 2007
    Messages : 731
    Points : 460
    Points
    460
    Par défaut
    Hello,

    Ne connaissant pas la taille du tableau avant d'en avoir fait la saisie, il te faut utiliser une allocation dynamique.
    Un exemple de ce qui peu être fait.
    A toi de te l’approprier en le réécrivant à ta façon.
    Si tu as des questions...

    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
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    #include <stdio.h>
    #include <stdlib.h>
     
    void afficher_tableau( long int *p, size_t p_sz );
    void tri_croissant   ( long int *p, size_t p_sz );
     
    int main()
    {
        //Demander la taille du tableau avant de procéder à son allocation
        size_t p_sz = 0;
        printf("\nTaille du tableau : ");
        scanf("%d", &p_sz);
     
        //Réaliser l'allocation du dit tableau
        long int *p = NULL;
        if ( ( p = malloc ( p_sz*sizeof(*p) ) ) )
        {
            //Si l'allocation réussie, on procède à la saisie des valeurs
            printf("\nSaisie des valeurs du tableau :\n");
            for( size_t i=0 ; i<p_sz ; i++ )
                printf("Saisie de l'element %u/%u : ", i+1, p_sz), scanf("%ld", &p[i]);
     
            //Le tableau étant initialisé, on peut effectuer son tri
            tri_croissant( p, p_sz );
     
            //Afficher le resultat du tri
            afficher_tableau( p, p_sz );
     
            //On libère la mémoire allouée pour le tableau p
            free(p);
        }
        return 0;
    }
     
    void afficher_tableau( long int *p, size_t p_sz )
    {
        printf("\n");
        if ( p )
            for ( size_t i=0 ; i<p_sz ; i++ )
                printf("\np[%u] = %u", i, p[i]);
    }
     
    void tri_croissant( long int *p , size_t p_sz )
    {
        if ( p ) // On vérifie que le pointeur est non NULL i.e alloué
        {
            long int swap = 0;
            for( size_t i=0 ; i<p_sz ; i++ )
                for( size_t j=i ; j<p_sz ; j++ )
                    if ( p[i]>p[j] )
                    {
                        swap = p[j];
                        p[j] = p[i];
                        p[i] = swap;
                    }
        }
    }
    UNE REPONSE UTILE : &|| UN PROBLEME RESOLU :

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

Discussions similaires

  1. [Dev-Pascal] [GNU Pascal] Problème d'affichage lors de l'exécution d'un programme
    Par Mourad III dans le forum Autres IDE
    Réponses: 2
    Dernier message: 03/11/2010, 02h19
  2. Problème Process / Affichage de l'output d'un autre programme
    Par fd_caramba dans le forum Débuter avec Java
    Réponses: 0
    Dernier message: 30/06/2009, 14h38
  3. [Dev-Pascal] Programme de combat naval : problème d'affichage
    Par deltarip dans le forum Autres IDE
    Réponses: 1
    Dernier message: 14/02/2009, 23h10
  4. problème d'affichage des programmes fini
    Par Porteuris dans le forum Débuter
    Réponses: 6
    Dernier message: 25/11/2008, 14h22
  5. [Programmation en C][Probléme d'affichage]
    Par ronan99999 dans le forum Windows
    Réponses: 7
    Dernier message: 01/09/2004, 11h47

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