我写了这段代码,我想知道我的问题是什么,如果你能帮我修复我自己写的代码,它会对我有很大帮助......编辑:我已经把它改成这个,现在它没有给我运行时错误,但是当我打印名称或检查节点是否存在时,它说它是......
void node_delete(friend *amit) // Deleting a node
{
friend* temp;
int flag = 0;
while (head != NULL) // As long the node isnt the last one
{
if (0 == (strcmp(head -> next -> name, amit -> name))) // If the name that the user entered matchs a name in the linked list,
{ // It'll skip it
temp = head -> next;
head -> next = head -> next -> next; // Deletes a node from the linked list
flag = 1;
}
if (flag == 1) break;
head = head -> next; // Going to the next node
}
free(temp); // Freeing the deleted node
printf ("%s\n", amit -> name);
}
主要是:
amit.name = "amit"
amit.age = 16
amit.gender = 'm'
node_delete(&amit);
和结构定义:
typedef struct friend // The struct
{
char *name;
int age;
char gender;
struct friend* next; // A pointer that points to the next node in the linked list
}friend;
非常感谢 :)