Linked list is a basic lesson in C, but it's fun to implement them.
#include <malloc.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
typedef struct {
int data;
struct Node *pNext;
} Node;
Why write this, because each manual malloc will be redundant, borrowed from the C++ new
Classic interview question, the difference between new and malloc
but cpp suggests using unique_ptr instead of bare pointers
About malloc without type conversion
Do I cast the result of malloc?
Node *mkNode(int value, Node *pNext)
{
Node *pNode = malloc(sizeof(Node));
if (pNode == NULL)
{
printf("分配失败程序退出!");
exit(-1);
}
pNode->data = value;
pNode->pNext = pNext;
return pNode;
};
Node *rec_create_list_from_arr(int *arr, size_t len, size_t i)
{
if (i == len)
return NULL;
return mkNode(arr[i], rec_create_list_from_arr(arr, len, i + 1));
}
void TraverseList(Node *pHead)
{
if (pHead == NULL)
return;
printf("%d", pHead->data);
TraverseList(pHead->pNext);
}
Node *nth_node(Node *node, int n)
{
if (node == NULL)
return NULL;
if (n == 0)
return node;
return nth_node(node->pNext, n - 1);
}
void join_list(Node *tail, Node *head)
{
tail->pNext = head;
}