当我尝试使用while循环建立链表时,循环的第二次迭代会更改全局头。这些值从文件中读入字符串(缓冲区),然后标记化以建立.name和.id的值。底部代码用于建立全局头。
struct node{
char name[50];
int id;
struct node* next;
}*head;
使用print语句,我设计了在循环的第二次迭代中更改head.name和head.id。如果有人有任何建议,请提供,因为他们非常感谢。
int read(){
char buffer[500];
char name[50];
int id;
struct node *temp;
head = NULL;
FILE *fp = fopen("AssignmentOneInput.txt", "r");
if(fp == NULL){
printf("Cant read.n");
return 0;
}
fgets(buffer, 500, fp);
head = malloc(sizeof(struct node));
strcpy(head->name, strtok(buffer, ","));
head->id = atoi(strtok(NULL, ","));
temp = head;
printf("%sn", head->name);
printf("%dn", head->id);
while(!feof(fp)){
fgets(buffer, 500, fp);
printf("%sn", head->name);
printf("%dn", head->id);
temp->next = malloc(sizeof(struct node));
strcpy(temp->name, strtok(buffer, ","));
temp->id = atoi(strtok(NULL, ","));
temp = temp->next;
if(temp == NULL){
fclose(fp);
return 1;
}
}}
文件AssignmentOneInput.txt包含以以下格式存储的值,尽管大约有20个而不是给定的1:
George Washington, 2345678
您需要在分配temp->name
和temp->id
之前而不是之后设置temp=temp->next
,否则您将覆盖上一个节点的数据。