链表实现分段错误
Linked list implementation segmentation fault
我已经完成了链表的基本实现,但是它在取消对注释行的注释时出现分段错误,否则它工作正常。
我无法理解为什么会出现错误。
请给我一些帮助
void insert(Node **head, Symbol sym) {
Node *temp, *p = *head;;
Symbol a = sym;
temp = (Node *)malloc(sizeof(Node));
temp->value = a;
temp->next = NULL;
if (p == NULL)
*head = temp;
else {
while (p->next != NULL)
p = p->next;
p->next = temp;
}
}
void printList(Node *head) {
Node *p = head;
if(p == NULL) return;
while (p != NULL) {
printf("%d ", p->value);
p = p->next;
}
printf("\n");
}
int main() {
Node *List, *list2;
insert(&List, 0);
insert(&List, 1);
//insert(&list2, 2);
//insert(&list2, 3);
printList(List);
return 0;
}
您没有初始化指向节点的初始指针
Node *List, *list2;
写
Node *List = NULL, *list2 = NULL;
考虑到您显示的程序中未使用变量 list2
。
另一种函数写法insert
如下
void insert( Node **head, Symbol sym )
{
Node *temp = malloc( sizeof( Node ) );
if ( temp != NULL )
{
temp->value = sym;
temp->next = NULL;
while ( *head ) head = &( *head )->next;
*head = temp;
}
}
我已经完成了链表的基本实现,但是它在取消对注释行的注释时出现分段错误,否则它工作正常。 我无法理解为什么会出现错误。 请给我一些帮助
void insert(Node **head, Symbol sym) {
Node *temp, *p = *head;;
Symbol a = sym;
temp = (Node *)malloc(sizeof(Node));
temp->value = a;
temp->next = NULL;
if (p == NULL)
*head = temp;
else {
while (p->next != NULL)
p = p->next;
p->next = temp;
}
}
void printList(Node *head) {
Node *p = head;
if(p == NULL) return;
while (p != NULL) {
printf("%d ", p->value);
p = p->next;
}
printf("\n");
}
int main() {
Node *List, *list2;
insert(&List, 0);
insert(&List, 1);
//insert(&list2, 2);
//insert(&list2, 3);
printList(List);
return 0;
}
您没有初始化指向节点的初始指针
Node *List, *list2;
写
Node *List = NULL, *list2 = NULL;
考虑到您显示的程序中未使用变量 list2
。
另一种函数写法insert
如下
void insert( Node **head, Symbol sym )
{
Node *temp = malloc( sizeof( Node ) );
if ( temp != NULL )
{
temp->value = sym;
temp->next = NULL;
while ( *head ) head = &( *head )->next;
*head = temp;
}
}