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 de pointeur?


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de Linu6
    Profil pro
    Inscrit en
    Août 2007
    Messages
    227
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 227
    Par défaut Problème de pointeur?
    Bonjour

    Voici une code qui compile très bien, mais qui pose un problème lors de l'exécution. L'erreur est au niveau de la fonction
    void f_opt(way_t *pchemin, char pville[][LG_MOT], int nb_ville);
    Voici le code ... (il est un peu sal, mais lisible quand mê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
    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
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    275
    276
    277
    278
    279
    280
    281
    282
    283
    284
    285
    286
    287
    288
    289
    290
    291
    292
    293
    294
    295
    296
    297
    298
    299
    300
    301
    302
    303
    304
    305
    306
    307
    308
    309
    310
    311
    312
    313
    314
    315
    316
    317
    318
    319
    320
    321
    322
    323
    324
    325
    326
    327
    328
    329
    330
    331
    332
    333
    334
    335
    336
    337
    338
    339
    340
    341
    342
    343
    344
    345
    346
    347
    348
    349
    350
    351
    352
    353
    354
    355
    356
    357
    358
    359
    360
    361
    362
    363
    364
    365
    366
    367
    368
    369
    370
    371
    372
    373
    374
    375
    376
    377
    378
    379
    380
    381
    382
    383
    384
    385
    386
    387
    388
    389
    390
    391
    392
    393
    394
    395
    396
    397
    398
    399
    400
    401
    402
    403
    404
    405
    406
    407
    408
    409
    410
    411
    412
    413
    414
    415
    416
    417
    418
    419
    420
    421
    422
    423
    424
    425
    426
    427
    428
    429
    430
    431
    432
    433
    434
    435
    436
    437
    438
    439
    440
    441
    442
    443
    444
    445
    446
    447
    448
    449
    450
    451
    452
    453
    454
    455
    456
    457
    458
    459
    460
    461
    462
    463
    464
    465
    466
    467
    468
    469
    470
    471
    472
    473
    474
    475
    476
    477
    478
    479
    480
    481
    482
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
     
    #define NB_VILLE 20
    #define LG_MOT 20
    #define NB_CHEMIN 5
     
            typedef struct way{
                short nxt_ville;
                short dist;
            }way_t;
     
                typedef struct nom{
                short num_ville;
                short num_suiv;
            }ITINERAIRE;
     
     
     
     
    //prototypes
    int menu();
    int f_ville(char ville[][LG_MOT], int nb_ville);
     
    int f_distance(way_t chemin[][NB_CHEMIN], char ville[][LG_MOT]);
     
    int f_parcours(way_t chemin[][NB_CHEMIN], char ville[][LG_MOT]);
     
    void f_opt(way_t *pchemin, char pville[][LG_MOT],  int nb_ville); //ITINERAIRE Citi[][NB_CHEMIN],
     
     
     
    // Fonction menu() affiche les opérations possibles, et renvoie
    //le numéro de l'opération choisi par l'utilisateur.
    int menu()
    {
        int c;
     
        printf("\n1 ville");
        printf("\n2 distance");
        printf("\n3 parcours");
    	printf("\n4 chemin le plus court");
        printf("\n5 exit\n");
     
        printf("\nchoisir une operation <1 2 3 4 5> : ");
        scanf("%d", &c);
     
        return c;
    }
     
    //Fonction ville(). remplit le tableau ville[][]
    //par des nom de ville.
    int f_ville(char ville[][LG_MOT], int nb_ville)
    {
        int i;
        //static int cpt=0;
        char tempon[LG_MOT];
     
        fflush(stdin);
        printf("\nSaisir le nom de la ville[%d]: ", nb_ville);
        scanf("%s", tempon);
     
        //renvoie -1, et actionne la sortie de la boucle
        //entammée dans main()
        if(strcmp(tempon, "exit")==0) return -1;
        //test si tempon[] existe déjà dans ville[][]
     
        for(i=0; i<nb_ville; i++)
        {
            if(strcmp(tempon, ville[i])==0)
            {
                printf("\nErr! La ville [%d] = %s existe deja\n", i, ville[i]);
                return 0;
             }
        }
        strcpy(ville[nb_ville], tempon);
        return 1;
    }
     
    //Fonction distance(). sasie ville de départ, ville d'arrivée et
    //affecte une longeur à la distance qui sépare les deux ville.
    int f_distance(way_t (*chemin)[NB_CHEMIN], char ville[][LG_MOT])
    {
        int depart, arrive, longueur;
        int i=0;
        int flag=0;
        char ville1[LG_MOT];
        char ville2[LG_MOT];
        //lit le nom de la ville de départ
        printf("Saisir le nom de la Ville de depart: ");
        scanf("%s", ville1);
        //si nom départ = exit -> sortir de la boucle
        if(strcmp("exit", ville1)==0) return 0;
        //saisit le nom de la ville d'arrivée
        printf("Saisir le nom de la Ville d/'arrive: ");
        scanf("%s", ville2);
        //si ville d'arrivé a le meme nom que ville de départ
        //resaisir nom ville d'arrivée
        if(strcmp(ville1, ville2)==0){
        do{
            printf("\nError: Saisissez, une ville d'arrive différente de la ville de depart!\n");
            printf("\nSaisir le nom de la Ville d/'arrive: ");
            scanf("%s", ville2);
            strcmp(ville1, ville2);
     
        }while(strcmp(ville1, ville2)==0);
        }
        //saisir la langueur de la distance
        printf("Saisir la longueur: ");
        scanf("%d", &longueur);
     
    //boucle compare ville1 avec l'ensemble des villes du tableau ville[][]
    do{
        //si ville1 (ville de départ) existe dans le tableau...
        if(strcmp(ville1, ville[i])==0)
        {   //..... affecter à la variable départ, l'indice de ville1 dans le tableau ville[][]
            depart=i;
            flag=1; //signifie que la ville de départ a été trouvé dans ville[][]
        }
        i++;
     
    }while(i<NB_VILLE);
        //...si ville1 (de départ) ne se trouvait pas dans ville[][]: msg Err!
        if(flag!=1)
        {
            printf("\n\nError: Item_1 ' %s ' not found!\n\n", ville1);
            return 0;
        }
    //repositionne flag, et initialise i.
    flag=0;
    i=0;
     
    //idem pour ville2 (ville d'arrivé), que ce qu'on a fait pour ville1
    do{
        if(strcmp(ville2, ville[i])==0)
        {
            arrive=i;
            flag=1;
        }
        i++;
    }while(i<NB_VILLE);
     
        if(flag!=1)
        {
            printf("Error: Item_2 ' %s ' not found!\n", ville2);
            return 0;
        }
     
        flag=0;
        i=0;
        //une boucle parcourt la matrice chemin,
        //Le premier indice = numéro de la ville départ reste fixe
        //la deuxième indice est incrémenté à chaque tour
        for(i=0; i<NB_CHEMIN; i++)
        {   //si la matrice [ville départ][i] n'est pas utilisé (c-à-d = -1)
            if((chemin[depart][i].nxt_ville)==-1)
            {   //...alors elle sert à enregister la nouvelle ville suivante avec
            //la distance qui la sépare de la ville de départ
                chemin[depart][i].nxt_ville=arrive;
                chemin[depart][i].dist=longueur;
                flag=1;
                break;
            }
        }
     
        //si flag n'a pas été modifie, signifie qu'on n'a pas trouvé de matrice telle que
        // chemin[depart][i].nxt_ville)==-1. On en conclue soit  une erreur de traitement
        //soit une saturation de ville suivante (cad, toutes les 5 case sont occupées)
     
        if(flag!=1)
        {
            printf("Probleme de liaison entre les villes ' %s ' et ' %s '\n", ville[depart], ville[arrive]);
            printf("Plus aucune ville n'est accessible depuis %s\n", ville[depart]);
            return 0; // la boucle entammée dans main() s'arrête,
            //mais les données entrées précedamment sont conservées.
        }
    return 1;
    }
     
     
     
    int f_parcours(way_t chemin[][NB_CHEMIN], char ville[][LG_MOT])
    {
        int i;
        int cur_ville;
        int suiv_ville;
        int longueur=0;
     
        for(i=0; ville[i][0]!='*' && i < NB_VILLE; i++)
        {
            printf("Ville[%2d] = %s\n", i, ville[i]);
        }
     
        printf("\nSaisir le numero de la ville <99 pour terminer>: ");
        scanf("%d", &cur_ville);
        if(cur_ville==99) {return 0;}
     
        i=0;
     
        suiv_ville=chemin[cur_ville][i].nxt_ville;
        longueur = chemin[cur_ville][i].dist;
     
        printf("|---depart---|---arrive---|distance|\n\n");
     
     
        while( (chemin[cur_ville][i].nxt_ville)!=-1){
            printf("%10s - %10s - %d Km\n", ville[cur_ville], ville[suiv_ville], longueur);
            //printf("Saisir le numero de la ville <99 pour terminer>: ");
            //scanf("%d", &cur_ville);
            if(cur_ville==99) {return 0;}
            i++;
            suiv_ville=chemin[cur_ville][i].nxt_ville;
            longueur = chemin[cur_ville][i].dist;
        }
        return 1;
    }
     
     
     
    void f_opt(way_t *pchemin, char pville[][LG_MOT], int nb_ville)//ITINERAIRE Citi[][NB_CHEMIN],
    {
    	int long_opti=3200, long_iti =0;
    	int optimal[NB_VILLE];
    	int ville_depart, ville_arrive;
    	int i;
    	int c=0;
     
     
     
    	int existe=0;
    	ITINERAIRE *Opti;
    	ITINERAIRE *Fin;
    	ITINERAIRE *Citi = pchemin;
    	ITINERAIRE *Fiti ;
     
    	int f=0;
     
    /* initialisation des pointeurs*/
     
    	Fiti = Citi;
    	Opti = Citi;
    	Fin = Citi;
     
    /* affichage des ville set des parcours*/
    	printf("\nchoix des villes\n");
     
    	for(i=0; pville[i][0]!='*' && i < NB_VILLE; i++)
    	{
    		printf("\n%i %s\n", i+1, pville[i]); 
    	}
     
    	/* saisi des parcours*/
     
    	printf("\n veuillez entrez la ville de depart: ");
    	scanf("%d", &ville_depart);
    	ville_depart--;
     
     
    	printf("\n veuillez entrez la ville de d'arrivee: ");
    	scanf("%d", &ville_arrive);
    	ville_arrive--;
     
    	/* décrémenter pour travailller de 0 à x */
    	/* 1ère phase initialisation du tableau DITI*/
     
    	Citi->num_ville = ville_depart;
    	Citi->num_suiv = 0;
    	/* 2ème phase , boucle effectuée jusqu’à la fin */
     
    	pchemin = pchemin + (ville_depart * NB_CHEMIN);
     
    	boucle :
    	do
    	{
    		if(pchemin->nxt_ville != -1)
    		{
    			do
    			{ 
    				if (pchemin->nxt_ville != Fiti->num_ville)
    				{
    					f++;
    					Fiti++;
    				}
    				else
    				{
    					existe = 1; 
    				}
    			}while (f<NB_VILLE && existe == 0);
    	/* initialisation du pointeur Fiti au début de Diti*/
     
    	Fiti = Fiti - f;
     
    	f = 0;
    			if (existe == 0)
    			{
    			Citi++;
    			Citi->num_ville = pchemin->nxt_ville;
    			//Citi->num_suiv=0 ;
    			Citi->num_suiv = 0;
    			long_iti = long_iti + pchemin->dist;
    			}
    			else{
    				Citi->num_suiv = Citi->num_suiv+1;
    			}
    		}
    		else
    		{
    			pchemin=pchemin-(ville_depart *NB_CHEMIN)-c;
    			Citi->num_ville = -1;
    			//Citi->num_suiv = 0 ;
    			Citi->num_suiv = 0;
    			Citi --;
    			if (Citi>= Fin)
    			{
    			ville_depart = Citi->num_ville;
    			c = Citi->num_suiv;
    			pchemin = pchemin + (ville_depart *NB_CHEMIN) + c;
    			/* je déduis la distance du chemin citi-> suiv*/
    		//	long_iti = long_iti - pchemin->dist ;
    			long_iti = long_iti - pchemin->dist;
    		//	Citi->num_suiv = Citi->num_suiv + 1 ;
    			Citi->num_suiv = Citi->num_suiv +1;
    			}
    		}
    		pchemin = pchemin - (ville_depart *NB_CHEMIN) -c;
    		ville_depart = Citi->num_ville;
    		c = Citi->num_suiv;
    		pchemin = pchemin + (ville_depart * NB_CHEMIN) + c;
    		existe = 0;
    	}while (Citi->num_ville != ville_arrive && Citi  >= Fin);
    /* on teste si long iti est le chemin iptimal */
    	if (long_iti < long_opti && Citi >= Fin)
    	{
    	long_opti = long_iti;
     
    		for (i = 0; i < NB_CHEMIN; i++)
    		{
    			optimal[i] = Opti ->num_ville;
    			Opti++;
    		}
    		Opti = Opti - 1;
    	}
     
    /* la ville d’arrivée a été trouvée, initialisation des variables*/
    	if (Citi > Fin)
    	{
    		Citi ->num_ville = -1;
    		Citi->num_suiv = 0;
    		Citi --;
     
    		pchemin = pchemin -(ville_depart * NB_CHEMIN) -c;
     
    		ville_depart = Citi->num_ville;
     
    		c = Citi->num_suiv;
     
    		pchemin = pchemin +(ville_depart * NB_CHEMIN) + c;
    		/* remise à jour de long iti*/
     
    		long_iti = long_iti - pchemin->dist;
     
    		Citi ->num_suiv = Citi ->num_suiv + 1;
     
    		pchemin = pchemin - (ville_depart * NB_CHEMIN) - c;
     
    		ville_depart = Citi->num_ville;
    		 c = Citi ->num_suiv;
    		pchemin = pchemin + (ville_depart * NB_CHEMIN) + c;
     
    		goto boucle ;
    	}
     
    /* 3ème phase Fiti est inférieur à Diti*/
     
    	printf("\n la longueur optimal est de : %i\n", long_opti);
    	i = 0;
     
    	printf("\n les villes à traverser sont: \n");
    	/*do
    	{
    		//int j = optimal[i];
    	printf("%s", *(pville + (optimal[i] * LG_MOT)));
    		//printf("%s", pville[j]);
    	i++;
    	}
    	while (optimal[i] != -1);*/
    }
     
    int main()
    {
    	int choix;
    	static int nb_ville =0;
    	int compar;
    	int i, j;
     
    	char ville[NB_VILLE][LG_MOT];
            //Initialise le nom des villes, pour ensuite
            //n'afficher que les villes effectives
    	for(i=0; i<NB_VILLE; i++){
    	        sscanf("*", "%c", ville[i]);
    	    }
     
            way_t chemin[NB_VILLE][NB_CHEMIN];
            //initialisation
            for(i=0; i<NB_VILLE; i++){
                for(j=0; j<NB_CHEMIN; j++){
                    chemin[i][j].nxt_ville=-1;
                    chemin[i][j].dist=0;
                }
            }
     
            //ITINERAIRE Citi[NB_VILLE][NB_CHEMIN];
     
            do{
    	    choix=menu();
    	    switch(choix)
    	    {
    	        case 1:
    	        printf("\n\nLancement de 'ville'  <exit pour terminer> \n\n");
    	        nb_ville=0;
    	        //la boucle continue tant qu'on peut lire une ville
    	        do{
                    compar=(f_ville(ville, nb_ville));
                    nb_ville++;
                   // si la ville existe, on décrémente
                   if(compar==0)
                   {
                       nb_ville--;
                   }
                   //la boucle s'arrête si ville[nb_ville] = exit
                   if(compar==-1)
                   {
                       nb_ville--;
                       break;
                   }
     
    	        }while(nb_ville<NB_VILLE);
     
                continue;
     
                case 2:
    	        printf("\nLancement de 'distance'  <exit pour terminer> \n\n");
     
                compar=f_distance(chemin, ville);
                while(compar!=0)
                {
                    compar=f_distance(chemin, ville);
     
                }
     
     
                continue;
     
                case 3:
    	        printf("\nLancement de 'parcours'  <00 pour terminer> \n\n");
     
    	        compar=f_parcours(chemin, ville);
     
    	         while(compar!=0)
                {
                    compar=f_parcours(chemin, ville);
     
                }
                continue;
     
    			case 4:
                printf("\nLancement d'optimisation de parcours  <00 pour terminer> \n\n");
     
                f_opt(*chemin, ville, nb_ville);
     
     
                continue;
     
    	        default: printf("\nAu revoir...\n");
    	        break;
    	    }
    	}while(choix > 0 && choix < 4);
     
     
    	return 0;
    }

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 23
    Par défaut
    Salut

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    pchemin = pchemin + (ville_depart * NB_CHEMIN);
    Est-ce correct ? pchemin est un pointeur sur une structure way_t. Tu veux faire quoi avec ca ?

  3. #3
    Membre confirmé Avatar de Linu6
    Profil pro
    Inscrit en
    Août 2007
    Messages
    227
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 227
    Par défaut
    Citation Envoyé par Nowoday Voir le message
    Salut

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    pchemin = pchemin + (ville_depart * NB_CHEMIN);
    Est-ce correct ? pchemin est un pointeur sur une structure way_t. Tu veux faire quoi avec ca ?
    J'initialise le premier membre de pchemin avec la valeur de "ville_depart" ... c'est légal non?

  4. #4
    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
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    void f_opt(way_t *pchemin, char pville[][LG_MOT], int nb_ville)//ITINERAIRE Citi[][NB_CHEMIN],
    {
    ...
    	ITINERAIRE *Citi = pchemin;
    Pourquoi initialiser un pointeur sur ITINERAIRE avec un pointeur sur way_t ???

  5. #5
    Membre confirmé Avatar de Linu6
    Profil pro
    Inscrit en
    Août 2007
    Messages
    227
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 227
    Par défaut
    Citation Envoyé par diogene Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    void f_opt(way_t *pchemin, char pville[][LG_MOT], int nb_ville)//ITINERAIRE Citi[][NB_CHEMIN],
    {
    ...
    	ITINERAIRE *Citi = pchemin;
    Pourquoi initialiser un pointeur sur ITINERAIRE avec un pointeur sur way_t ???
    Au fait je veux me servir de pchemin comme d'un tableau. Et Citi donne la position de la ville courante dans le tableau.

  6. #6
    Scorpi0
    Invité(e)
    Par défaut
    Si tu veux de l'aide, commence par enlever les choix de tes menus, pré remplis les toi même, donne nous un code qui compile et qui s'exécute immédiatement, parce que là, j'ai même pas envie de voir ce que fait le code si je me perd dans 12 menus !!

Discussions similaires

  1. Problème de pointeurs..embrouillé
    Par Frenchy dans le forum C++
    Réponses: 11
    Dernier message: 10/03/2005, 16h33
  2. Problème de pointeur avec un TQuery
    Par Oluha dans le forum Bases de données
    Réponses: 3
    Dernier message: 25/01/2005, 13h57
  3. Problème de pointeur
    Par toma_lille dans le forum C++
    Réponses: 1
    Dernier message: 07/12/2004, 21h26
  4. [MFC] Problème de pointeur !!
    Par acastor dans le forum MFC
    Réponses: 7
    Dernier message: 19/03/2004, 15h50
  5. TBitmap et problèmes de pointeurs...
    Par benj63 dans le forum C++Builder
    Réponses: 8
    Dernier message: 28/07/2003, 13h39

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