我正在尝试从bst中删除节点 符合以下条件:((strcmp((**)-> caracterise.nom,Etud.nom)== 0)&&(strcmp((**)-> caracterise.prenom,Etud.prenom)== 0)&&(( * A)-> caracterise.note == Etud.note)
我在'* A'中收到成员'caracterise'的[错误]请求,该请求的指针类型为'ABR {aka noud *}'(也许您打算使用'->'吗?)
注意:学员是学生;节点是节点;特点是学生信息; nom名词注释是姓氏家族名称gpa; fG被保留; fD是正确的; ABR是BST
struct etudiant
{
char nom[13];
char prenom[13];
float note;
};
struct noud
{
etudiant caracterise;
struct noud*fG;
struct noud*fD;
};
typedef struct noud*ABR;
void supprimer(ABR** A, etudiant Etud){
if ((strcmp((*A)->caracterise.nom , Etud.nom) == 0) && (strcmp((*A)->caracterise.prenom , Etud.prenom) == 0) && ((*A)->caracterise.note == Etud.note)) {
//if ((test(*A, Etud) == 0)&& (*A->caracterise.note == Etud.note)){
ABR* a;
a = (ABR*)malloc (sizeof(noud));
a = (*A)->fD ;
ABR* b;
b = (ABR*)malloc (sizeof(noud));
if ( a != NULL ) {
if ( a->fG != NULL ) {
while ( a->fG->fG != NULL ) {
a = a->fG ;
}
b = a->fG ;
b->fG = (*A)->fG ;
a->fG = b->fD ;
b->fD = (*A)->fD;
a = (*A);
(*A) = b ;
free(a);
}else{
a->fG = (*A)->fG ;
free(*A);
(*A) = a ;
}
}else{
a = *A ;
(*A) = (*A)->fG ;
free(a);
}
}else{
if ( v.priorite > (*A)->val.priorite ) {
supprimer(&(*A)->fD, Etud);
}else{
supprimer(&(*A)->fG, Etud);
}
}
}
答案 0 :(得分:0)
A 是ABR**
,所以是struct noud***
,所以(*A)
是struct noud**
而不是struct noud*
和{{ 1}}是错误的(但(*A)->caracterise
是合法的)