数据结构-链表(1)

来源:互联网 发布:数据库 锁定客户群 编辑:程序博客网 时间:2024/05/25 01:34

先说一下什么是链表。链表就是一个链子,把数据都连接在一条线上,而这些数据,就是链子上的铁扣,链表里面叫做(数据)节点。

先用一个图,来表示一下链表的具体构造。

链表的构造如下:


从图中可以看出,链表中每一个数据节点都是由两部分组成,数据部分以及一个指向下一个节点的指针(只是说单向的,也就是非循环单链表)

链表的几个特有的存在,也在图中显示出来。


其中的头节点,是人为的加上的,他的指针指向首节点。首节点指的是第一个具有有效数据的节点,头节点指向他,所以说是不存放有效数据的。头节点的存在主要是为了方便对链表的操作。头指针就是一个指针,指向了头节点,相同的还有一个尾指针,指向的是尾节点。

如果想要确定一个链表,那么只需要一个头指针,就可以得出链表的所有信息。

贴出代码,从注释中理解链表:


#include <stdio.h>#include <malloc.h>#include <stdlib.h>typedef struct Node{int data;//数据域,这里存放的是想要存储的数据struct Node * pNext;//指针域,这里的存放的是下一个节点的地址}NODE, *PNODE;//用typedef函数,就是type的define,使得NODE等价于struct Node,PNODE等价于struct Node *//声明了两个函数PNODE create_list();//链表创建的函数,用于创建一个非循环单链表int traverse_list(struct Node *);//用于输出链表int main(){PNODE pHead = NULL;//等价于 struct Node * pHead = NULL;pHead = create_list();//create_list()功能:创建一个非循环单链表,并将该链表的头结点的地址赋给pHeadtraverse_list(pHead);//链表中数据一个一个输出return 0;}PNODE create_list(){int len;//用来存放有效节点的个数int i;int val;//用来临时存放用户输入的结点的值PNODE pHead = (PNODE)malloc(sizeof(NODE));//分配了一个不存放有效数据的头结点if (NULL == pHead){//这里的写法是一种安全的做法,如果不小心把==写成了=,NULL=pHead是会报错的,而pHead=NULL就会当做赋值然后返回true处理printf("分配失败, 程序终止!\n");exit(-1);}/*        这里设定pTail的原因是:            链表的操作原理是将新的节点挂在尾节点上            而尾节点没有办法表达出来            所以增加一个pTail来作为尾节点            方便下面的pNew挂上去*/PNODE pTail = pHead;pTail->pNext = NULL;printf("请输入您需要生成的链表节点的个数: len = ");scanf("%d", &len);for (i=0; i<len; ++i){printf("请输入第%d个节点的值: ", i+1);scanf("%d", &val);PNODE pNew = (PNODE)malloc(sizeof(NODE));if (NULL == pNew){printf("分配失败, 程序终止!\n");exit(-1);}/*            第一句pNew->data = val;可以放在下面四个语句的任意位置            第二句是将pNew挂在尾节点上            第三句是将pNew的指针域设定为空,意思是这是新的尾节点            第四句是将pTail变成新的尾节点,使得循环操作成立*/pNew->data = val;pTail->pNext = pNew;pNew->pNext = NULL;pTail = pNew;}return pHead;}int traverse_list(PNODE pHead){    //定义一个指针,从首节点开始PNODE p = pHead->pNext;//判定,若p不为NULL,输出p所对应节点的数据,然后指针移向下一个节点while (NULL != p){printf("%-5d", p->data);p = p->pNext;}printf("\n");return 0;}

0 0