在线计算网 · 发布于 2025-02-01 22:59:02 · 已经有10人使用
在编程的世界里,数据结构是构建复杂系统的基石。而单链表作为一种基础且重要的数据结构,掌握其基本操作对于提升编程技能至关重要。今天,我们就来深入探讨C语言中单链表的基本操作。
单链表是一种线性数据结构,由一系列节点组成,每个节点包含数据部分和指向下一个节点的指针。其结构简单,操作灵活,广泛应用于各种场景。
struct Node {
int data;
struct Node* next;
};
struct Node* createNode(int data) {
struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
newNode->data = data;
newNode->next = NULL;
return newNode;
}
void insertAtHead(struct Node** head, int data) {
struct Node* newNode = createNode(data);
newNode->next = *head;
*head = newNode;
}
void insertAtTail(struct Node** head, int data) {
struct Node* newNode = createNode(data);
if (*head == NULL) {
*head = newNode;
return;
}
struct Node* temp = *head;
while (temp->next != NULL) {
temp = temp->next;
}
temp->next = newNode;
}
void deleteAtHead(struct Node** head) {
if (*head == NULL) return;
struct Node* temp = *head;
*head = (*head)->next;
free(temp);
}
void deleteAtTail(struct Node** head) {
if (*head == NULL) return;
if ((*head)->next == NULL) {
free(*head);
*head = NULL;
return;
}
struct Node* temp = *head;
while (temp->next->next != NULL) {
temp = temp->next;
}
free(temp->next);
temp->next = NULL;
}
struct Node* search(struct Node* head, int key) {
struct Node* temp = head;
while (temp != NULL) {
if (temp->data == key) return temp;
temp = temp->next;
}
return NULL;
}
#include <stdio.h>
#include <stdlib.h>
struct Node {
int data;
struct Node* next;
};
struct Node* createNode(int data) {
struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
newNode->data = data;
newNode->next = NULL;
return newNode;
}
void insertAtHead(struct Node** head, int data) {
struct Node* newNode = createNode(data);
newNode->next = *head;
*head = newNode;
}
void insertAtTail(struct Node** head, int data) {
struct Node* newNode = createNode(data);
if (*head == NULL) {
head = newNode;
return;
}
struct Node temp = *head;
while (temp->next != NULL) {
temp = temp->next;
}
temp->next = newNode;
}
void deleteAtHead(struct Node** head) {
if (head == NULL) return;
struct Node temp = *head;
*head = (*head)->next;
free(temp);
}
void deleteAtTail(struct Node** head) {
if (*head == NULL) return;
if ((*head)->next == NULL) {
free(*head);
head = NULL;
return;
}
struct Node temp = *head;
while (temp->next->next != NULL) {
temp = temp->next;
}
free(temp->next);
temp->next = NULL;
}
struct Node* search(struct Node* head, int key) {
struct Node* temp = head;
while (temp != NULL) {
if (temp->data == key) return temp;
temp = temp->next;
}
return NULL;
}
int main() {
struct Node* head = NULL;
insertAtHead(&head, 10);
insertAtTail(&head, 20);
insertAtTail(&head, 30);
deleteAtHead(&head);
deleteAtTail(&head);
struct Node* found = search(head, 20);
if (found != NULL) {
printf("Found: %d\n", found->data);
} else {
printf("Not Found\n");
}
return 0;
}
通过本文的学习,相信你已经掌握了C语言中单链表的基本操作。无论是创建、插入、删除还是查找节点,这些操作都是构建复杂数据结构的基础。希望你在实际编程中能够灵活运用,不断提升自己的编程能力。
《数据结构与算法分析》
C语言标准库文档
1484次Python Web开发教程:掌握表单字段类型,提升编程实战能力
1441次精影RX 5500 XT 8G电源推荐:如何选择合适的瓦数
1391次JMeter性能测试教程:详解HTTP信息头管理器
1206次技嘉GeForce GTX 1660 SUPER MINI ITX OC 6G参数详解:小巧强芯,游戏利器
1174次深入理解Go Web开发:URI与URL的区别与应用
1139次JavaScript函数参数详解:掌握前端编程核心技巧
1020次七彩虹战斧RTX 3060 Ti豪华版LHR显卡参数详解:性能强悍,性价比之王
590359次四川话女声语音合成助手
104991次生辰八字计算器
73208次4x4四阶矩阵行列式计算器
67027次情侣恋爱日期天数计算器
62973次各种金属材料重量在线计算器
54996次分贝在线计算器
51473次任意N次方计算器
49798次经纬度分秒格式在线转换为十进制
49596次卡方检验P值在线计算器
43010次三角函数计算器