在 C 编程中将链表添加到另一个链表

Posted

技术标签:

【中文标题】在 C 编程中将链表添加到另一个链表【英文标题】:Adding a linked list to another linked list in C programming 【发布时间】:2022-01-21 11:44:30 【问题描述】:

我是初学者尝试使用 c 将链表添加到另一个链表。问题是程序正在进入无限循环,我不知道为什么。 这是下面的c代码

typedef struct bookInfo

    int code;
    struct bookInfo *next;
 bookInfo;

typedef struct subscriber

    int code;
    struct bookInfo *books;
    struct subscriber *next;
    struct subscriber *prec;
 subscriber;

typedef bookInfo *Book;
typedef subscriber *Subscriber;
typedef Subscriber *SubscriberList;

void newBook(Book *bk, int val)

    bookInfo *new_node = malloc(sizeof(bookInfo));
    bookInfo *last = *bk;
    new_node->code = val;
    new_node->next = NULL;

    if (*bk == NULL)
    
        *bk = new_node;
    
    else
    
        while (last->next != NULL)
            last = last->next;
        last->next = new_node;
    


Subscriber Add_book(Subscriber S, Book Bk)

    bookInfo *newNode = malloc(sizeof(bookInfo));
    bookInfo *tmp;
    newNode->next = NULL;
    newNode->code = Bk->code;
    if (S == NULL)
        printf("\nl'abonnee est nulle");
    else
    
        if (S->books == NULL)
            S->books = newNode;    
        else
        
            tmp = S->books;
            while (tmp != NULL)
                tmp = tmp->next;
            tmp->next = newNode;
            printf("\nl'ajout du livre a ete effectue");
        ;
    
    return S;
;

希望你们能帮助我,谢谢。我不知道是函数 newBook 中的问题还是什么,这是我的主要函数

int main()

    book_ref, sub_ref = NULL;
    newSubscriber(&sub_ref);
    bookInfo b1 = 20,NULL;
    Add_book(sub_ref, &b1);
    printf("\n%d : %d", sub_ref->code, sub_ref->books->code);

【问题讨论】:

你应该学习如何使用调试器,因为它是有价值的。调试器是您自己解决此类问题的绝佳工具。 Wassim Ben Fatma,很好奇,为什么使用Subscriber S 而不是subscriber * S 据我所知,您需要一个指针才能更改全局变量。但我不知道我的工作是否正确。我真的是 C 编程的初学者。 我知道这似乎是一个深奥的抱怨,但错误消息确实属于 stderr。 fprintf(stderr, "...");。永远不要将错误消息写入标准输出。 【参考方案1】:

在您的代码中,

while (tmp != NULL) tmp = tmp->next; 当此循环结束时,tmp 为 NULL,因此下一行将尝试访问空指针。

你应该更正它,while(tmp->next != NULL)

【讨论】:

我修好了,但问题仍然存在 对于给定的代码段,我们只能说这么多。共享代码的其他相关部分。你为什么要返回 S ?这个 Add_book() 如何在您的其余代码中使用。【参考方案2】:

为了消除无限循环,我所要做的就是将订阅者结构中的书籍指针定义为NULL

void newBook(Book *bk, int val)

    bookInfo *new_node = malloc(sizeof(bookInfo));
    bookInfo *last = *bk;
    new_node->code = val;
    new_node->next = NULL;
    new_node->books = NULL;

    if (*bk == NULL)
    
        *bk = new_node;
    
    else
    
        while (last->next != NULL)
            last = last->next;
        last->next = new_node;
    


Subscriber Add_book(Subscriber S, Book Bk)

    bookInfo *newNode = malloc(sizeof(bookInfo));
    bookInfo *tmp;
    newNode->next = NULL;
    newNode->code = Bk->code;
    newNode->books = NULL;
    if (S == NULL)
        printf("\nl'abonnee est nulle");
    else
    
        if (S->books == NULL)
            S->books = newNode;    
        else
        
            tmp = S->books;
            while (tmp != NULL)
                tmp = tmp->next;
            tmp->next = newNode;
            printf("\nl'ajout du livre a ete effectue");
        ;
    
    return S;
;

一切正常。

【讨论】:

你的bookInfo结构没有名为books的成员,不清楚你在做什么,newNode->books

以上是关于在 C 编程中将链表添加到另一个链表的主要内容,如果未能解决你的问题,请参考以下文章

在C中将结构添加到结构链表中

用C语言写一个链表储存学生信息

使用指针向链表添加值,而无需在 C 中使用 strdup()

C++并发编程:线程安全链表

C++并发编程:线程安全链表

C++并发编程:线程安全链表