学習のために、簡単な連結リストの実装を書いています。リンクされたリストは、値と次のノードへのポインターをnode
含む構造で構成されています。int
コードを実行すると、NULL ポインターに達したときに終了する必要があるにもかかわらず、無限にループします。私は何を間違っていますか?
#include <stdio.h>
struct node {
int value;
struct node *next_node;
};
struct node * add_node(struct node *parent, int value)
{
struct node child;
child.value = value;
child.next_node = NULL;
parent->next_node = &child;
return parent->next_node;
}
void print_all(struct node *root)
{
struct node *current = root;
while (current != NULL) {
printf("%d\n", current->value);
sleep(1);
current = current->next_node;
}
}
int main()
{
struct node root;
root.value = 3;
struct node *one;
one = add_node(&root, 5);
print_all(&root);
}