阅读量:2
是的,在C语言中,你可以自定义链表的节点结构
#include
#include
// 自定义节点结构
typedef struct Node {
int data; // 数据域,用于存储数据
struct Node* next; // 指针域,用于指向下一个节点
} Node;
// 创建新节点的函数
Node* create_node(int data) {
Node* new_node = (Node*) malloc(sizeof(Node));
new_node->data = data;
new_node->next = NULL;
return new_node;
}
// 向链表中添加节点的函数
void add_node(Node** head, int data) {
Node* new_node = create_node(data);
if (*head == NULL) {
*head = new_node;
} else {
Node* current = *head;
while (current->next != NULL) {
current = current->next;
}
current->next = new_node;
}
}
// 打印链表的函数
void print_list(Node* head) {
Node* current = head;
while (current != NULL) {
printf("%d -> ", current->data);
current = current->next;
}
printf("NULL\n");
}
int main() {
Node* head = NULL;
add_node(&head, 1);
add_node(&head, 2);
add_node(&head, 3);
print_list(head);
return 0;
}
在这个示例中,我们定义了一个名为Node的结构体,它包含一个整数数据域data和一个指向下一个节点的指针域next。我们还创建了几个用于操作链表的函数,如create_node、add_node和print_list。在main函数中,我们创建了一个空链表并向其中添加了一些节点,然后打印了链表。
以上就是关于“C语言链表操作能自定义节点吗”的相关介绍,筋斗云是国内较早的云主机应用的服务商,拥有10余年行业经验,提供丰富的云服务器、租用服务器等相关产品服务。云服务器资源弹性伸缩,主机vCPU、内存性能强悍、超高I/O速度、故障秒级恢复;电子化备案,提交快速,专业团队7×24小时服务支持!
简单好用、高性价比云服务器租用链接:https://www.jindouyun.cn/product/cvm