本文介绍: 链表是一种常见的重要的数据结构。它是动态地进行存储分配的一种结构。在用数组存放数据时,必须事先定义固定的长度(即元素个数)。链表则没有这种缺点,它根据需要开辟内存单元。链表有一个“头指针“变量,图中以 head 表示,它存放一个地址,该地址指向一个元素。链表中每一个元素称为”结点”,每个结点都应包括两个部分:用户需要用的实际数据和下一个结点的地址,也称为数据域和指针域。可以看出,head 指向第一个元素;
链表
链表是一种常见的重要的数据结构。它是动态地进行存储分配的一种结构。在用数组存放数据时,必须事先定义固定的长度(即元素个数)。链表则没有这种缺点,它根据需要开辟内存单元。
链表有一个“头指针“变量,图中以 head 表示,它存放一个地址,该地址指向一个元素。链表中每一个元素称为”结点”,每个结点都应包括两个部分:用户需要用的实际数据和下一个结点的地址,也称为数据域和指针域。可以看出,head 指向第一个元素;第一个元素又指向第二个元素……直到最后一个元素,该元素不再指向其他元素,它称为”表尾”,它的地址部分放一个”NULL”( 表示”空地址”),链表到此结束。
链表中各元素在内存中可以不是连续存放的。要找某一元素,必须先找到上一个元素,根据它提供的下一元素地址才能找到下一个元素。如果不提供“头指针”(head),则整个链表都无法访问。
我们可以这样设计结构体类型:
其中成员num和score用来存放结点中的有用数据(用户需要用到的数据),相当于上图结点中的 A,B,C,D。next 是指针类型的成员,它指向 struct student 类型数据(这就是next 所在的结构体类型)。一个指针类型的成员既可以指向其他类型的结构体数据,也可以指向自己所在的结构体类型的数据。现在,next是struct student 类型中的一个成员,它又指向struct student 类型的数据。用这种方法就可以建立链表。
建立链表
首先,链表分为有头链表和无头链表
在本文章中,我们主要研究“有头单向链表”
空链表 ——代表头节点的next指针指NULL
链表的插入
头插法
step1:首先是创建新节点
struct Node *pNew = malloc (sizeof(struct Node));
pNew->data = 100;
step2:将新节点插入链表
struct Node *pNew= malloc(sizeof(stiuct Node));
pNew->data= 100;
(1).pNew->next = pHead->next;
(2).pHead->next = pNew;
尾插法
链表遍历
计算链表中有效节点的个数
头删法
尾删法
链表销毁
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。