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 :

Tri d'un tableau


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 47
    Par défaut Tri d'un tableau
    Bonjour.

    C'est simple. Le bug est situé au niveau de la fonction get_max, elle marche pour un tableau avec 3 entrees dedans, a partir de 4 jai une erreur access violation blabla :s

    Quelquun aurait une idee comment resoudre ca ?
    Ah wai, les methodes de tri existent deja, mais cest pour un TP de prog a l'ecole

    code:
    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
     
    #include "stdafx.h"
    #include <iostream>
    #include <conio.h>
    #include <math.h>
     
     
     
    int _tmain(int argc, _TCHAR* argv[]) {
    	int n = 1;
    	std::cin >> n;
    	std::cout << "Remplissage du tableau avec n=" << n << " valeurs..." << std::endl;
    	int table[] = {0};
    	fill(table,n);
    	sort(table,n);
    	getch();
    }
    void fill(int *t,int s) {
    	for(int i=0;i<s;i=i+1) {
    		t[i] = rand();
    		std::cout << "valeur a n=" << i <<" est " << t[i] << std::endl;
    	}
    }
    void sort(int *t, int s) {
    	int max = get_max(t,s);
    	std::cout << "le maximum est: " << t[max] <<" a n=" << max << std::endl;
    }
    int get_max(int *t, int s) {
    	int w[] = {t[0],0};
    	for(int i = 0;i<s;i=i+1) {
    		if(t[i] > w[0]) { w[0] = t[i]; w[1] = i; }
    	}
    	return w[1];
    }

  2. #2
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Par défaut
    ta variable int table[] = {0}; n'est jamais allouée. Il te manque probablement le malloc une fois que l'utilisateur a saisi la taille du tableau
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 47
    Par défaut
    Avant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    int table[] = {0};
    Apres:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    	int *table = {0};
    	table = (int *)malloc(n*sizeof(int));
    Okay la fonction get_max fonctionne, ty

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 47
    Par défaut Tri d'un tableau 2 :v
    Re ~
    J'ai appuyé trop tot sur résolu xD

    New petit probleme,

    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
     
    void sort(int *t, int s, int d) {
    	/*
    	* mon idée:
    	* On va faire une boucle qui se repete s fois (c'est a dire le nombre de valeurs dans notre tableau)
    	* pour chaque iteration, on recupere le maximum du tableau (cf. get_max(int *t, int s);)
    	* et en fonction du tri (ASC ou DESC) on va placer cette valeur a la fin ou au debut de notre tableau
    	*/
    	int *table_cpy = {0};
    	table_cpy = (int *)malloc(sizeof(t));
    	table_cpy = t;
    	int max = get_max(table_cpy,s);
    	int min = table_cpy[get_min(table_cpy,s, max)]-1;
    	int cpos = (d == SORT_ASC) ? s : 0;
    	for(int i = 0; i < s; i = i + 1) {
    		max = get_max(table_cpy,s);
    		t[cpos] = table_cpy[max];
    		//std::cout << "max ("<<cpos<<"):" <<t[cpos]<<std::endl;
    		table_cpy[max] = min;
    		//std::cout << "table_cpy output (pos:"<<max<<"):" <<table_cpy[max]<<std::endl;
    		//std::cout << "t output (pos:"<<cpos<<"):" <<t[cpos]<<std::endl;
    		//if(d == SORT_ASC) cpos = cpos-1;
    		//else cpos = cpos+1;
    	}
    }
    Bon, si je met pas les // devant le dernier if&else, ca ne trie plus.
    De plus, j'apelle la fonction avec SORT_ASC, et il me trie en SORT_DESC :[
    Jme dis que ca doit juste etre une petite rectification, le gros probleme cest que normalement, mon if & else final sert pour savoir où stocker le maximum dans t, donc si jlutilise pas, il m'affiche le trie avec std::cout, mais le stocke pas :s

    Thanks

    nico

  5. #5
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    Il y a dès le début des confusions :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    void sort(int *t, int s, int d) {
    ....
    	int *table_cpy = {0};
    // On initialise un pointeur avec NULL : int *table_cpy = NULL;
    	table_cpy = (int *)malloc(sizeof(t));
    //sizeof (t) ne donne pas du tout la taille d'un tableau "t", mais la
    //taille d'un int * (typiquement 4 octets) puisque t est un int *
    	table_cpy = t;
    //ne copie pas le contenu d'un tableau dans un autre, mais change 
    //(et écrase  la valeur obtenue par le malloc) la valeur du pointeur table_cpy

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 47
    Par défaut
    Ok jai corrigé ca.

    mais le probleme du if & else a la fin perciste.

    idée ?

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    iostream et std::cout, c'est du C++, pas du C. Si tu fais du C, compile en C.

    De plus, la description de ton tri ressemble à un tri par sélection, mais j'ai du mal à comprendre comment tu le fais: Tu cherches à faire le tri en in-place sur la copie, ou à remplir la "copie" au fur et à mesure que tu tries?
    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.

  8. #8
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    Citation Envoyé par secksy Voir le message
    Ok jai corrigé ca.

    mais le probleme du if & else a la fin perciste.

    idée ?
    Poste le code actuel, qu'on sache exactement où on en est.

  9. #9
    Membre confirmé
    Inscrit en
    Mars 2006
    Messages
    117
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Mars 2006
    Messages : 117
    Par défaut
    je te conseil si tu n'es pas sur de ton algo de tri, ou si tu ne sais pas trop quel tri tu appliques d'aller lire les differents algo de tri existants. Il y a un article sur wikipedia ici :

    http://fr.wikipedia.org/wiki/Algorithme_de_tri
    il y a des exemples et explication de chaque algorithmes existants.
    Attention il y a meme des exemples de code, le but est de les comprendres, pas les appliquer betement

    bon courage

  10. #10
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par secksy Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    #include "stdafx.h"
    #include <iostream>
    Pas du C. Je déplace ?

  11. #11
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 47
    Par défaut
    ah bon iostream cest pas du c ?
    et dans stdafx ya juste les declarations dmes fonctions :v

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    stdafx.h, c'est du C, c'est juste un fichier d'en-tête du projet (en supposant que l'option "en-têtes précompilés" est désactivée dans le projet).

    <iostream>, cout, namespace etc. sont du C++.
    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.

  13. #13
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    47
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 47
    Par défaut
    Mon prof de prog a l'iut a dis que cout c'est du C.

  14. #14
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Par défaut
    Citation Envoyé par secksy Voir le message
    Mon prof de prog a l'iut a dis que cout c'est du C.
    Hé oui, mais les profs, ils n'ont pas toujours raison ...

    cout, c'est du C++
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  15. #15
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par secksy Voir le message
    Mon prof de prog a l'iut a dis que cout c'est du C.
    Change de prof.

Discussions similaires

  1. Tri d'un tableau en 2D
    Par sniperseb dans le forum C
    Réponses: 4
    Dernier message: 05/01/2006, 16h33
  2. Réponses: 6
    Dernier message: 16/09/2005, 10h30
  3. tri d'un tableau à 2 dimensions
    Par dede92 dans le forum C
    Réponses: 4
    Dernier message: 19/02/2005, 18h29
  4. [langage] Probleme de tri d'un tableau de tableau
    Par Ludo167 dans le forum Langage
    Réponses: 1
    Dernier message: 25/08/2004, 10h32
  5. [] Tri d'un tableau par ordre alphabétique
    Par cafeine dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 17/09/2002, 08h43

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