用C语言设计尾插法建立带头结点的单链表的函数
时间: 2023-05-28 18:07:38 浏览: 101
C语言实现头插法、尾插法两种方法来构建带头结点的单链表
以下是使用C语言设计尾插法建立带头结点的单链表的函数的示例代码:
#include <stdio.h>
#include <stdlib.h>
// 定义单链表结构体
typedef struct ListNode {
int val;
struct ListNode *next;
} ListNode;
// 尾插法建立单链表
ListNode* createList() {
ListNode *head = (ListNode*)malloc(sizeof(ListNode)); // 创建头结点
head->next = NULL; // 初始化为空链表
ListNode *tail = head; // 尾指针指向头结点
int n, val;
printf("请输入链表中节点的个数:");
scanf("%d", &n);
printf("请输入链表中各节点的值:");
for (int i = 0; i < n; i++) {
scanf("%d", &val);
// 创建新节点
ListNode *newNode = (ListNode*)malloc(sizeof(ListNode));
newNode->val = val;
newNode->next = NULL;
// 将新节点插入到尾部
tail->next = newNode;
tail = newNode;
}
return head;
}
// 打印单链表
void printList(ListNode *head) {
ListNode *p = head->next; // 头结点不用打印
while (p) {
printf("%d ", p->val);
p = p->next;
}
printf("\n");
}
int main() {
ListNode *head = createList();
printList(head);
return 0;
}
阅读全文