У меня есть домашние задания, которые просят меня сюда вставить из текстового документа 100 студентов имена и идентификаторы, отформатированные как (Фамилия Имя ID) объявление затем положить в двух бинарных деревьев поиска. Основной BST будет содержать фамилии и указатель на другой BST, который будет содержать имена и идентификаторы. Это первый раз, когда я буду trynig использовать указатели (*, ->, &), так что я потерялся. Мне удалось импортировать текст со следующей функцией
void loadData(char fname[], Students *st){
struct Students *new;
root=NULL;
int i;
FILE *fp;
fp=fopen(fname,r);
if (fp == NULL) printf(File does not exist\n);
fscanf(fp, %d, &(st->size)); //reads the number of students
free(st->name);
st->name=(Name*) malloc(st->size*(sizeof(Name)));
for (i=0; i<st->size; i++){
fscanf(fp, %s,&st);
insert(root,st.surname);/////////I think here is the problem
//fscanf(fp, %s, &st->name[i].firstname);
// fscanf(fp, %d, &st->name[i].id);
}
fclose(fp);
}
И теперь я пытаюсь создать функцию вставки, которая очень трудно для меня, потому что я не могу понять аргументы, которые она должна принять
STU *insert(STU *node, char *sname)///What should i use here to save take the Surname??
{
if(node==NULL){
node=(NODE *) malloc(sizeof(STU));
strcpy(node->surname);
node->left=NULL;
node->right=NULL;
}
else{
if(strcmp(*sname, node->surname)<0)
insert(node->left, *sname);
else if(strcmp(*sname, node->surname)>0)
insert(node->right, *sname);
}
return node;
}
Вот определение структуры:
typedef struct Name{
char firstname[20];
int id;
struct Students *nameleft;
struct Students *nameright;
} Name;
typedef struct Students{
char surname[20];
Name *name;
int size;
struct Students *left;
struct Students *right;
} Students;
typedef struct Students STU;
struct Students *insert(char num);
struct Students *root=NULL;
Может кто-нибудь помочь мне исправить функцию вставки, потому что я не могу понять, какие аргументы я должен использовать, чтобы сохранить фамилию, и я буду делать все остальное сам. Я думаю, что моя проблема заключается функция вставки. Спасибо, в любом случае.













