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 par insertion


Sujet :

C

  1. #1
    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 Tri par insertion
    Bonjour,

    Je dois effectuer une fonction de tri par insertion de valeurs entrées via le main, mais ça déconne pas mal en fait. Je ne trouve pas l'erreur.

    Voici le 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
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
     
    #include<stdio.h>
    #include<stdlib.h>
     
     
    int *insere(int *tableau, int valeur, int taille); 
     
    int main(void)
    {
     
     
     
         int *T;
     
         T=malloc(20*sizeof(int));
     
         int j;
         for ( j=0 ; j < 20 ; j++ )
             {
                   T[j]=10*j;
             }
     
     
     
         char control='o';
         int valeur;
         int nouvelle_taille=20;
     
         printf(" SAISIR 'n' POUR QUITTER LA SAISIE DES VALEURS et 'o' POUR CONTINUER \n\n");
     
         while ( control != 'n')
               {
                             printf(" Veuillez saisir un entier : ");
                             scanf("%d",&valeur);
                             nouvelle_taille++;
                             T = insere(T, valeur, nouvelle_taille);
                             printf("\nCONTINUER (o/n) : ");
                             scanf("%s",&control);
     
               }
     
        int i;
        for ( i=0 ; i < nouvelle_taille ; i++ )
            {
                  printf("\nT[%d]=%d", i, T[i]); 
                  getch();
            }
    }
     
     
     
     
    int *insere(int *tableau, int valeur, int taille) 
    {
     
        tableau=realloc(tableau, taille*sizeof(int));
        int inser;
     
        int l=0;
        for ( l=0 ; l < taille ; l++ )
            {
                  if ( valeur >= tableau[l] ) 
                     {
                           inser=l;
                     }
     
            }
     
        int m;    
        for ( m=(taille-1) ; m<inser ; m-- )
            {
                      tableau[m+1]=tableau[m];
            }
     
        tableau[inser+1]=valeur;
        return tableau;
    }


    Si vous avez des suggestions, je suis preneur !
    Merci d'avance

  2. #2
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 381
    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 381
    Points : 41 582
    Points
    41 582

  3. #3
    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
    Oui désolé, je vais trop vite !
    En fait, la valeur à insérée s'insère mais le tableau ne se décale pas correctement donc au final une des valeurs est écrasée et la nouvelle case ajoutée soit la dernière affiche la valeur de l'adresse de la case mémoire. Je me suis donc trompé dans ma boucle pour décaler les valeur je suppose.

  4. #4
    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
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for ( m=(taille-1) ; m>inser ; m-- )
    J'ai mis un < au lieu d'un > o.0 !

    Maintenant quand j'essaye de rentrer plus de 3 valeurs à la suite le programme plante !?

  5. #5
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 381
    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 381
    Points : 41 582
    Points
    41 582
    Par défaut
    Je te conseillerais de gérer tableau et réallocation avec une structure:
    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
    36
    37
    38
    39
    40
    41
    42
    43
    44
    struct TableauInt
    {
    	int *tab;
    	size_t cElems;
    };
     
    int reallocTableauInt(struct TableauInt *pTableau, size_t newcElems)
    {
    	size_t newcb = newcElems * sizeof *pTableau->tab; /*nouvelle taille en octets*/
    	int *tmp = realloc(pTableau->tab, newcb);
    	if(tmp == NULL)
    		return -1; /*erreur*/
     
    	pTableau->tab = tmp;
    	pTableau->cElems = newcElems;
    	return 0;
    }
     
    void decalerIntDroite(struct TableauInt *pTableau, size_t indexDebut)
    {
    	size_t i;
    	for(i=pTableau->cElems-1 ; i>indexDebut ; --i)
    		pTableau->tab[i] = pTableau->tab[i-1];
    }
     
    /* Decale les éléments indexDebut et suivants vers la gauche.
       pTableau->tab[indexDebut-1] est écrasé. */
    void decalerIntGauche(struct TableauInt *pTableau, size_t indexDebut)
    {
    	size_t i;
    	for(i=indexDebut ; i < pTableau->cElems ; ++i)
    		pTableau->tab[i-1] = pTableau->tab[i];
    }
     
    int insererTableau(struct TableauInt *pTableau, size_t index, int valeur)
    {
    	/* Augmente de 1 la taille du tableau */
    	if(reallocTableauInt(pTableau, pTableau->cElems+1) < 0)
    		return -1;
     
    	/* Décale les autres valeurs vers la droite et insère la nouvelle valeur */
    	decalerIntDroite(pTableau, index);
    	pTableau->tab[index] = valeur;
    }

  6. #6
    Membre confirmé

    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Août 2007
    Messages
    509
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Août 2007
    Messages : 509
    Points : 622
    Points
    622
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Je te conseillerais de gérer tableau et réallocation avec une structure:
    Ou avec une Liste chainée !!!

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

Discussions similaires

  1. besoin d'aide pour le tri par insertion.
    Par argon dans le forum Algorithmes et structures de données
    Réponses: 19
    Dernier message: 18/05/2006, 11h15
  2. tri par insertion et Structures
    Par bonjour69 dans le forum C
    Réponses: 2
    Dernier message: 23/12/2005, 12h46
  3. [LG] Le tri par insertion d'un enregistrement
    Par phoebee dans le forum Langage
    Réponses: 4
    Dernier message: 01/09/2005, 20h38
  4. [LG]Tri par insertion dans une liste chainée
    Par mister_dsg dans le forum Langage
    Réponses: 4
    Dernier message: 18/12/2003, 22h34

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