我试图将我的列表打印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/

10-11 22:50
查看更多