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'assignation de valeur dans un tableau


Sujet :

C

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2020
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 22
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2020
    Messages : 1
    Points : 1
    Points
    1
    Par défaut problème d'assignation de valeur dans un tableau
    bonjour, étant un petit nouveau dans la prog en C j'ai plusieurs questions, la première est celle-ci:

    (j'utilise code block comme IDE)


    le principe appliqué pour le tri est le suivant:
    1. prendre la première valeur du tableau
    2. la comparer à toutes les valeurs du tableau dont le pointeur est supérieur a celui de la valeur a comparer
    3. si une valeur inférieure existe, l'échanger de place avec la première
    4. répéter l'opération autant de fois que nécessaire pour que la plus petite valeur soit en premier
    5. refaire l'opération à partir de la deuxième valeur, puis de la troisième,...



    pour assigner et trier des valeurs dans un tableau, j'ai créé ce code (ci-dessous), la partie de création du tableau et celle d'assignation initiale des valeurs fonctionnent, en revanche la partie de tri ne fonctionne pas,
    en fait, une des assignation ne se fait pas, c'est la deuxième.

    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
    int main()
    {
     
    void imp_tab(int t[], int nb_elem)
    {
    int i;
     
    for (i = 0; i < nb_elem; i++) printf("%d ",t[i]);
    }
     
    {
        int size=1;
        int table[size];
        int value = 0;
        int y = 0;
        int recup=0;
        int recup2=0;
        int res;
     
        printf("Entrez une valeur pour la taille : ");
                res = scanf("%i", &size);
     
     
        while(y<size)
            {
                printf("Entrez une valeur pour le rang %i : ",y);
                res = scanf("%i", &value);
                table[y]=value;
                y++;
            }
    //algo de tri   (V)
    for (int o = 0; o < y-1; o++)
        {
     
        for (int r = o+1; r < y; r++)
            {
                    recup=table[o];
                    recup2=table[r];
            if (table[r]<table[o])
                {
                    table[r]=recup;
                    table[o]=recup2;//l'assignation ne se fait pas
                }
     
            }
     
        }
     
     
    imp_tab(table,y);
    return 0;
    }
    si quelqu'un a une idée, je veux bien parce que là, je sèche.

  2. #2
    Expert éminent
    Homme Profil pro
    Ingénieur développement matériel électronique
    Inscrit en
    Décembre 2015
    Messages
    1 565
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement matériel électronique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Décembre 2015
    Messages : 1 565
    Points : 7 648
    Points
    7 648
    Par défaut
    Bonjour,

    En langage C, on ne peut pas définir une fonction à l'intérieur d'une autre. Ton compilateur semble tolérer cela mais les lignes 4 à 9 devraient être en dehors de la fonction main().

    En langage C, on peut définir un tableau donc la taille dépend d'une variable. Mais cette règle était surtout source de problème et va disparaître, la preuve : Tu as utilisé cette capacité ligne 13 en créant un tableau dont la taille vaut finalement 1. Donc le seul indice utilisable est 0.
    Ensuite tu écris dans ce tableau à des indices y qui peuvent être supérieur à 0. Et dans ce cas cela provoques des fonctionnement complètement erratiques. Et c'est vraisemblablement la cause de tes erreurs.
    Ton tri, quant à lui, semble correct.

  3. #3
    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
    Bonjour
    Citation Envoyé par dalfab Voir le message
    En langage C, on ne peut pas définir une fonction à l'intérieur d'une autre. Ton compilateur semble tolérer cela
    Si le compilateur le tolère, c'est donc qu'on peut non ?

    En tout cas mon gcc (8.3.0 sur debian10) l'accepte lui-aussi...
    Code c : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    #include <stdio.h>
     
    int main() {
    	void toto() {
    		printf("toto\n");
    	}
     
    	toto();
    }
    ... et ça fait quelques mois que je m'en suis rendu compte. Donc force est de constater qu'apparemment maintenant on peut...
    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]

  4. #4
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Avec les bonnes options de norme et -pedantic pour désactiver les extensions GNU?
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  5. #5
    Membre expérimenté Avatar de Ngork
    Homme Profil pro
    Barbare IT
    Inscrit en
    Avril 2009
    Messages
    160
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Barbare IT
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2009
    Messages : 160
    Points : 1 372
    Points
    1 372
    Par défaut
    Comme l'indique dalfab, tu déclares un tableau de taille size, avec size initialisé à 1, par conséquent, ton tableau est aussi initialisé à 1.
    Or ultérieurement, tu donnes une autre valeur à size, d'après l'entrée de l'utilisateur, et tu espères visiblement que le tableau va changer de taille pour s'adapter à la nouvelle valeur de size.
    Ce n'est pas le cas.
    Il te suffit de déplacer la ligne de déclaration de ton tableau après la saisie de l'utilisateur et il fera la bonne taille, ce qui devrait résoudre tes soucis ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
      printf("Entrez une valeur pour la taille : ");
      res = scanf("%i", &size);
     
      int table[size];
    Bien sûr, il faudrait quand même que tu contrôles un peu ce que rentre l'utilisateur histoire d'éviter les valeurs négatives ou la valeur nulle !

  6. #6
    Expert éminent sénior
    Homme Profil pro
    Analyste/ Programmeur
    Inscrit en
    Juillet 2013
    Messages
    4 630
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Analyste/ Programmeur

    Informations forums :
    Inscription : Juillet 2013
    Messages : 4 630
    Points : 10 556
    Points
    10 556
    Par défaut
    Citation Envoyé par Ngork Voir le message
    Il te suffit de déplacer la ligne de déclaration de ton tableau après la saisie de l'utilisateur et il fera la bonne taille, ce qui devrait résoudre tes soucis ...
    Sauf que dans ce cas , ce n'est toléré que depuis C99 ... et je pense même que comme le tableau est un VLA (Variable-length array, lien wiki en anglais), il faut impérativement C99 (mais déprécié depuis C11)

    Et si @D_bar voulait correctement faire un VLA, il faut passer la taille en paramètre ... mais dans son code ce n'est pas possible parce que la taille doit être demandée : donc à part faire une allocation dynamique, il faut créer le tableau le + grand possible


    Et pour les fonctions imbriquées , cela fait partie de la GNU C (<- lien officiel gnu en anglais) apparemment cela ressemble à des lambdas qui sont déclarées au même niveau que les autres variables (en gros, on crée une variable lambda)

  7. #7
    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 Médinoc Voir le message
    Avec les bonnes options de norme et -pedantic pour désactiver les extensions GNU?
    Ben non, j'ai juste lancé un bête "gcc". C'est sûr que si on active les options qui interdisent ce type de programmation ben ça marchera pas. Avec "--pedantic" il me met un warning mais il le compile quand-même.

    Citation Envoyé par foetus Voir le message
    Et si @D_bar voulait correctement faire un VLA, il faut passer la taille en paramètre ... mais dans son code ce n'est pas possible parce que la taille doit être demandée
    Euh non, là je ne suis pas d'accord. Les VLA (et ton lien le dit bien) sont des tableaux dont la taille est déterminée lors de l'exécution. Donc de mon point de vue, une taille saisie au clavier permet un VLA. D'ailleurs l'exemple C de ton lien montre un VLA qui reçoit la taille en paramètre mais rien ne dit que la taille en question n'a pas été saisie au clavier du côté appelant.

    Mais bien éidemment si comme ici le VLA est créé avant que la taille ne soit saisie...

    Citation Envoyé par foetus Voir le message
    Et pour les fonctions imbriquées , cela fait partie de la GNU C (<- lien officiel gnu en anglais) apparemment cela ressemble à des lambdas qui sont déclarées au même niveau que les autres variables (en gros, on crée une variable lambda)
    Ce serait marrant d'essayer de passer l'adresse d'une fonction incluse à une autre fonction voir si l'autre fonction peut l'appeler...

    Edit: hé bien ça marche !!!
    Code c : 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
    #include <stdio.h>
     
    void caller(void (*)(char*));
     
    int main() {
    	void toto(char *s) {
    		printf("%s\n", s);
    	}
     
    	caller(toto);
    }
     
    void caller(void (*f)(char*)) {
    	(*f)("123");
    	(*f)("456");
    }
    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]

  8. #8
    Expert éminent sénior
    Homme Profil pro
    Analyste/ Programmeur
    Inscrit en
    Juillet 2013
    Messages
    4 630
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Analyste/ Programmeur

    Informations forums :
    Inscription : Juillet 2013
    Messages : 4 630
    Points : 10 556
    Points
    10 556
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Euh non, là je ne suis pas d'accord. Les VLA (et ton lien le dit bien) sont des tableaux dont la taille est déterminée lors de l'exécution. Donc de mon point de vue, une taille saisie au clavier permet un VLA. D'ailleurs l'exemple C de ton lien montre un VLA qui reçoit la taille en paramètre mais rien ne dit que la taille en question n'a pas été saisie au clavier du côté appelant.

    Mais bien évidemment si comme ici le VLA est créé avant que la taille ne soit saisie...
    Tu as raison , il faudrait découper l'algo en 2 : dans un premier temps demander la taille du tableau et ensuite le créer, le remplir, et le trier.

    Mais, je ne sais pas, je pense que lorsque j'ai vu le code de @Ngork et lui dire de le faire en 2 parties, avec la deuxième partie dans une fonction (pour passer la taille en paramètre), j'ai lâché l'affaire


    Citation Envoyé par Sve@r Voir le message
    Edit: hé bien ça marche !!!
    Mais c'est une variable locale avec une notion de fermeture ("closure" en anglais, lien wiki en français)

    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
    #include <stdio.h>
    #include <stdlib.h>
     
     
    typedef void (*t_func)(char*);
     
     
    // Forward Declaration
    void caller(t_func, char*, char*);
     
     
    t_func give_me_the_func(char* debug_str, char* first_str, char* seconde_str) {
        void toto01(char *s) {
            if (s != NULL) {
                printf("%s\n", s);
            } else {
                printf("%s\n", debug_str);
            }
        }
     
        void toto02(char *s) {
            printf("%s\n", s);
        }
     
        toto01(NULL);
     
        caller(toto02, first_str, seconde_str);
     
        return toto02;
    }
     
     
    int main(int argc, char* argv[])
    {
        t_func func01 = give_me_the_func("main - debug: take the first func", "first func: 01", "first func: 02");
        t_func func02 = give_me_the_func("main - debug: take the second func", "second func: 01", "second func: 02");
     
        caller(func01, "kaboum: 01", "kaboum: 02");
     
     
        return EXIT_SUCCESS;
    }
     
     
    void caller(t_func f, char* first_str, char* seconde_str) {
        (*f)(first_str);
        (*f)(seconde_str);
    }

  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 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 foetus Voir le message
    Tu as raison , il faudrait découper l'algo en 2 : dans un premier temps demander la taille du tableau et ensuite le créer, le remplir, et le trier.
    C'est ce qu'il fait (lignes 20 et 21). Il faut juste qu'il définisse le tableau après la saisie.

    Citation Envoyé par foetus Voir le message
    Mais, je ne sais pas, je pense que lorsque j'ai vu le code de @Ngork et lui dire de le faire en 2 parties, avec la deuxième partie dans une fonction (pour passer la taille en paramètre), j'ai lâché l'affaire
    C'est pas grave on est tous bénévoles. Si tu peux aider tu aides et si tu peux pas ben personne ne t'en voudra.
    D'autant plus que je viens de reprendre son code et en fait il fonctionne. Juste définir le tableau après la saisie et c'est bon.
    Code c : 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
    #include <stdio.h>
    int main() {
    	void imp_tab(int t[], int nb_elem) {
    		int i;
    		for (i = 0; i < nb_elem; i++) printf("%d ",t[i]);
    	}
     
    	int size;
    	int y;
    	int res;
     
    	printf("Entrez une valeur pour la taille : ");
    	res = scanf("%i", &size);
    	int table[size];
     
    	for (y=0; y< size; y++) {
    		printf("Entrez une valeur pour le rang %i : ",y);
    		res = scanf("%i", &table[y]);
    	}
     
    	//algo de tri   (V)
    	for (int o = 0; o < y-1; o++) {
    		for (int r = o+1; r < y; r++) {
    			if (table[r]<table[o]) {
    				int tmp;
    				tmp=table[r];
    				table[r]=table[o];
    				table[o]=tmp;
    			}
    		}
    	}
     
    	imp_tab(table,y);
    	return 0;
    }
    Je l'ai un peu optimisé en enlevant les variables non nécessaires mais le code d'origine fonctionne aussi.

    Comme quoi, voilà comment briller à peu de frais
    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]

  10. #10
    Expert éminent sénior
    Homme Profil pro
    Analyste/ Programmeur
    Inscrit en
    Juillet 2013
    Messages
    4 630
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Analyste/ Programmeur

    Informations forums :
    Inscription : Juillet 2013
    Messages : 4 630
    Points : 10 556
    Points
    10 556
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Juste définir le tableau après la saisie et c'est bon.
    @Ngork l'avait dit, sur ce je lui retoqué que c'est du C99 mais remarqué que ce n'est pas gênant parce que @D_bar utilisait déjà des VLA et toi tu es arrivé après

Discussions similaires

  1. Réponses: 3
    Dernier message: 07/11/2019, 09h31
  2. [PowerShell] Problème affectation de valeur dans un tableau
    Par Lutin1801 dans le forum Scripts/Batch
    Réponses: 1
    Dernier message: 05/01/2017, 12h42
  3. Réponses: 9
    Dernier message: 10/09/2015, 00h34
  4. problème de valeur dans un tableau se trouvant dans une liste
    Par alaninho dans le forum Général Python
    Réponses: 5
    Dernier message: 16/06/2011, 10h17
  5. [Tableaux] Problème de valeur dans un tableau (array)
    Par Flushovsky dans le forum Langage
    Réponses: 15
    Dernier message: 24/03/2006, 13h56

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