C语言链表总结

链表和数组作为算法中的两个基本数据结构,在程序设计过程中经常用到。尽管两种结构都可以用来存储一系列的数据,但又各有各的特点。
链表的特性,使其在某些操作上比数组更加高效。因为链表在内存中不是连续存储的,所以可以充分利用内存中的碎片空间。除此之外,链表还是很多算法的基础,最常见的哈希表就是基于链表来实现的。基于以上原因,我们可以看到,链表在程序设计过程中是非常重要的。本文总结了我们在学习链表的过程中碰到的问题和体会。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
三种不同的方法,挺不错的! #include<stdio.h> #include<stdlib.h> #include<string.h> #define N 100 typedef struct SList { char data[N]; //字符数组 struct SList *next; //定义链表头指针 }SList,*ListPointer; /*typedef struct List { SList *head; }List,* ListPointer; */ void initList(ListPointer &lp) { lp=(SList *)malloc(sizeof(SList));//初始化链表 lp->next=lp; //链表的头指针指向本身,实现链表循环 } void output(ListPointer lp) // 自定义输出函数 { SList *ep; ep=lp; while(ep->next!=lp) //判定条件 当指针重新指向头指针输出结束 { ep=ep->next; printf("%s ",ep->data); } } void revert(ListPointer lp) // 链表的逆置 { SList *p,*q; p=lp;q=NULL;lp=NULL; while(p) { q=p->next; p->next=lp; lp=p; p=q; } /*方法二 SList *p,*q,*end; p=lp->next; q=p->next; end=p; while(q!=lp) { lp->next=q; q=q->next; lp->next->next=p; p=lp->next; } end->next=lp; */ } void add_char(char *p,ListPointer lp) //将输入的字符传递给链表 { SList * ep; ep=lp; while(ep->next!=lp) //判定条件 当指针重新指向头指针输出结束 { ep=ep->next; } ep->next=(SList *)malloc(sizeof(SList)); //开辟空间存储 strcpy(ep->next->data,p); //字符的传递 ep->next->next=lp; } void main() { ListPointer L; char str[N]; initList(L); printf("输入#以结束\n");//确定输入终止条件 while(1) { scanf("%s",str); if(*str=='#') //判定条件 { break; } add_char(str,L); } printf("初始序列为:"); output(L); printf("\n"); revert(L); printf("逆置后为:"); output(L); printf("\n"); }
链表是一种常见的数据结构,C语言中也提供了链表的实现方式。链表由多个节点组成,每个节点包含数据和指向下一个节点的指针。链表的优点是可以动态地增加或删除节点,缺点是查找某个节点时需要遍历整个链表链表的基本操作包括创建链表,添加节点,删除节点和遍历链表。具体实现如下: 1. 创建链表 创建链表需要定义一个链表结构体,包含节点指针和链表长度等信息。示例代码如下: ``` typedef struct Node { int data; struct Node* next; } Node; typedef struct List { Node* head; int length; } List; List* createList() { List* list = (List*) malloc(sizeof(List)); list->head = NULL; list->length = 0; return list; } ``` 2. 添加节点 添加节点需要先创建一个新节点,并将其加入链表末尾。示例代码如下: ``` void addNode(List* list, int data) { Node* newNode = (Node*) malloc(sizeof(Node)); newNode->data = data; newNode->next = NULL; if (list->head == NULL) { list->head = newNode; } else { Node* cur = list->head; while (cur->next != NULL) { cur = cur->next; } cur->next = newNode; } list->length++; } ``` 3. 删除节点 删除节点需要先找到要删除的节点,并将其从链表中移除。示例代码如下: ``` void deleteNode(List* list, int data) { Node* cur = list->head; Node* prev = NULL; while (cur != NULL && cur->data != data) { prev = cur; cur = cur->next; } if (cur == NULL) { return; } if (prev == NULL) { list->head = cur->next; } else { prev->next = cur->next; } free(cur); list->length--; } ``` 4. 遍历链表 遍历链表需要从头节点开始,依次访问每个节点的数据。示例代码如下: ``` void traverseList(List* list) { Node* cur = list->head; while (cur != NULL) { printf("%d ", cur->data); cur = cur->next; } printf("\n"); } ``` 以上是C语言链表的基础操作,掌握这些知识可以让你更好地理解链表的实现原理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值