我试图将我的列表打印3次以上。
应该是这样的
A: 5 B: 2 C: 3
A: 6 B: 4 C: 1
A: 7 B: 3 C: 15
A: 5 B: 2 C: 3
A: 6 B: 4 C: 1
但是第三次之后,它崩溃了。
请看一下我的代码,并向我展示如何修复它。
PS:此外,我可以在第二次/第三次运行中编辑列表的值吗?
提前致谢,,
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
struct list {
int a,b,c;
struct list *next;
};
struct list *init_list ( int a, int b, int c );
void list_print( struct list *list );
struct list *init_list ( int a, int b, int c ){
struct list *list;
list = malloc(sizeof(struct list));
if (list == NULL) {
printf("Error: Memory allocation failure.\nTerminating.\n");
exit(1);
}
list->a = a;
list->b = b;
list->c = c;
list->next = NULL;
return (list);
}
void list_print(struct list *list) {
int j = 0;
struct list *list2;
do {
list2 = list;
struct list *tmp;
tmp = list;
printf("A: %d B: %d C: %d\n" ,tmp->a, tmp->b, tmp->c);
list = list->next;
j++;
} while (j < 4);
}
int main (int argc, const char * argv[])
{
struct list *linked_list_1, *linked_list_2;
linked_list_1 = init_list(5, 2, 3);
linked_list_1->next = init_list(6, 4, 1); linked_list_2 = linked_list_1->next;
linked_list_2->next = init_list(7, 3, 15);
list_print(linked_list_1);
return 0;
}
最佳答案
据我了解,您有list1-> list2-> list3-> NULL。
因此,当j = 0时,您打印list1,然后移至list2。 j现在等于1,则打印list2并移至下一个元素,j = 2再次打印并移至NULL。尝试打印NULL指针的内容会使程序崩溃
关于c - C语言中的简单链表实现,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/7673652/