SOS algorithme - Page 3

Précédent
  • 1
  • 2
  • 3
coco
 
Error : pointer/array required
main.c line 56 tabsquence[*g]->tabmachine[numachine]->tabordo[k]->numjob=numtache;

Error : cannot convert
'struct squence (*)[15]' to
'int *'
main.c line 115 Recherche( &tabsquence,&g);

je recoit ces deux erreur mais je comrend pas ce que ca veut dire
0
KX Messages postés 19031 Statut Modérateur 3 020
 
Est-ce que tu pourrais expliquer en français ce que tu veux faire, parce qu'avec ton code C, je ne vois pas du tout quel est ton but, ni de quelle façon tu utilises la première partie de ton problème
0
coco
 
il faut voir les urnes comme des machines et les boule comme des taches ou cahque tache a ces catreristiques
la 1 er partie consiste a genere toute les possibilite s d'ffectation des tache aux machines , lalgo que tu as fait deja .
la seconde il faut que je prend chaque sequence (cas ) avec les machine (urne) et pour chaque machine les tache que elle a traiter ,puis pour chaque cas je doit calcule un critre d'optimisation (c'est une autre fonction ) et au final il faut que j arrive a avoir le num de la sequance les taches traiter et dans quelle machine sont traiter
je crois ke c clair maintenant
0
KX Messages postés 19031 Statut Modérateur 3 020
 
Je pense pas qu'il y ait grand chose à changer dans le code 26 (hormis la conversion du C++ au C et les notations urne=machine, boule=tâche, solution=séquence)

En rajoutant une variable globale int Cpt=0; et une structure :
struct cas={int num_sequence; sequence s; critere_optimisation c; };

Je dirais qu'il faudrait compléter Enregistrer(solution s; int M) à peu près comme ça :
{
num_sequence= ++Cpt; // numéro de séquence
cas.s=s;
cas.c=optimisation(s);
}
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
coco
 
slt
j essyer de faire un exemple avec la structure pour le 1 er cas ca marche
mais pour le 2 cas il excute la boucle for (numtache=0; numtache<nbtache; numtache++) just pour numtache =0 ,et puis il s'arret ( il n'incremente pas numtache) ,
je sais pas porkoi

typedef Bool solution[Nm][Nm];
//la tache numtache est dans la machine numachine si s[numtache-1][numchine-1] est vrai

void Enregistrer(solution s, int M, int *g,struct squence *tabsquence ) // ici un simple affichage, modifiable à volonté
{

int numtache,numachine,k,machinit;
k=0;
machinit=0;

for (numachine=0; numachine<M; numachine++)
{
printf("Machine %d : ",numachine );
for (numtache=0; numtache<nbtache; numtache++){ --------------------------> ici

if (s[numachine][numtache]==true){
printf(" %d ",numtache);

if (numachine==machinit){

tabsquence[*g].tabmachine[numachine].tabordo[k].numjob=numtache;
k++ ;
}
else machinit=numachine;
tabsquence[*g].tabmachine[numachine].tabordo[0].numjob=numtache;
k=1;
}
}
printf("\n");
}

*g=*g+1;
printf("\n");
}
0
coco
 
merci tt le monde pour votre aide surtout un grand merci pur KX qui a ete d'une grand aide
merci encore
0
Précédent
  • 1
  • 2
  • 3