Я пытаюсь изучить методы вставки в Связанный список. Во время выполнения он сбрасывает каждый раз, говоря, что программа перестала работать. Он не обнаружил никаких ошибок. Я новичок в Stack Overflow. Так что простите меня, если этот вопрос уже задан. Вот мой код:Почему моя программа рушится каждый раз, когда я запускаю ее?
#include<stdio.h>
#include<stdlib.h>
struct node{
int data;
struct node *next;
};
void push(struct node** head_ref, int new_data)
{
struct node* new_node= (struct node*)malloc(sizeof(struct node));
new_node->data=new_data;
new_node->next=(*head_ref);
(*head_ref)=new_node;
}
void insertAfter(struct node* prev_node, int new_data)
{
if(prev_node==NULL)
{printf("The previous node cannot be NULL");
return;
}
struct node* new_node=(struct node*)malloc(sizeof(struct node));
new_node->data=new_data;
new_node->next=prev_node->next;
prev_node->next=new_node;
}
void append(struct node** head_ref, int new_data)
{
struct node* new_node= (struct node*)malloc(sizeof(struct node));
struct node *last= *head_ref;
new_node->data=new_data;
new_node->next=NULL;
if(*head_ref==NULL)
{
*head_ref=new_node;
}
else
while(last->next!=NULL)
{
last=last->next; /* Segmentation fault */
}
last->next=new_node;
return;
}
void printlist(struct node *node)
{
while(node!=NULL)
{
printf("%d",node->data);
node=node->next;
}
}
int main()
{
struct node* head=NULL;
append(&head,6);
push(&head,7);
push(&head,11);
append(&head,4);
insertAfter(head->next,12);
printf("\n Created Linked list is:");
printlist(head);
return 0;
}
Используйте отладчик, сначала сузите оскорбительную инструкцию. –
Ну, теперь он сказал что-то о недостатке сегментации. Как вы это исправите? (Извините, я до сих пор не знаком с программированием) –
Также некоторые форматирование вашего кода не пойдет не так. –