链表——C语言——day17

链表

链表是一种常见的重要的数据结构。它是动态地进行存储分配的一种结构。在用数组存放数据时,必须事先定义固定的长度(即元素个数)。链表则没有这种缺点,它根据需要开辟内存单元。
在这里插入图片描述
链表有一个“头指针“变量,图中以 head 表示,它存放一个地址,该地址指向一个元素。链表中每一个元素称为"结点",每个结点都应包括两个部分:用户需要用的实际数据和下一个结点的地址,也称为数据域和指针域。可以看出,head 指向第一个元素;第一个元素又指向第二个元素……直到最后一个元素,该元素不再指向其他元素,它称为”表尾”,它的地址部分放一个"NULL"( 表示"空地址"),链表到此结束。

链表中各元素在内存中可以不是连续存放的。要找某一元素,必须先找到上一个元素,根据它提供的下一元素地址才能找到下一个元素。如果不提供“头指针”(head),则整个链表都无法访问。

我们可以这样设计结构体类型:

struct student 
{	int num; float score;struct student * next;
};

其中成员num和score用来存放结点中的有用数据(用户需要用到的数据),相当于上图结点中的 A,B,C,D。next 是指针类型的成员,它指向 struct student 类型数据(这就是next 所在的结构体类型)。一个指针类型的成员既可以指向其他类型的结构体数据,也可以指向自己所在的结构体类型的数据。现在,next是struct student 类型中的一个成员,它又指向struct student 类型的数据。用这种方法就可以建立链表。
在这里插入图片描述

建立链表

首先,链表分为有头链表和无头链表

在这里插入图片描述

在本文章中,我们主要研究“有头单向链表”

空链表 ——代表头节点的next指针指NULL

void initList(struct Node *pHead)
{pHead->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;
在这里插入图片描述

我们可以将头插法函数写成这样:
void pushFront(struct Node *pHead,int n)
{struct Node *pNew = malloc (sizeof(struct Node));  // 在堆上创建空间pNew->data= n;  //输入新节点的数据pNew->next = pHead->next;	//将头节点的指针域上的地址赋值给新节点指针域pHead->next = pNew;	//头节点的指针域上的地址指向新节点
}
尾插法

step1:首先是创建新节点
step2:定位到尾节点

定位到尾节点:
while(p->next != NULL)
{
p = p->next;
}

step3:将新节点插入链表
在这里插入图片描述
但是,我们需要考虑如果链表本身是个空链表,怎么尾插?并且还需要判断链表是否为空?
所以,我们将尾插法可以写成这样:

int isEmpty(struct Node *pHead) //判断链表是否为空链表
{return pHead->next == NULL;
}void pushBack(struct Node *pHead, int n)
{if(isEmpty(pHead)){pushFront(pHead, n);	//空的话直接使用头插法}else{struct Node *pNew= mallcc(sizeof(struct Node));pNew->data=n;struct Node *p = pHead->next;while(p->next){p = p->next;}p->next = pNew;pNew->next = NULL;}
}
链表遍历

在这里插入图片描述
只要p不为NULL,直接输出数据即可。

void printList(struct Node *pHead)
{struct Node *p;p =pHead->next;while(p != NULL){printf("&d\n", p->data);p = p->next;}
}
计算链表中有效节点的个数
size_t length(struct Node *pHead)
{size_t ret =0;struct Node *p= pHead->next;while(p){++ret;p = p->next;}return ret;
}
头删法

在删除的时候,我们首先要确定链表是否为空,若链表为空,则不能删除。
在这里插入图片描述
首先,头节点的地址域指针指向p->next的地址,随后释放p即可。

void popFront(struct Node *pHead)
{if(!isEmpty(pHead)){struct Node *p= pHead->next;pHead->next = p->next;free(p);}
}
尾删法

在这里插入图片描述
我们首先要判断链表是否为空,为空的话直接结束,随后判断链表中是否至少有两个以上的有效节点,如果只有一个节点,直接转到头删法即可。

void popBack(struct Node *pHead)
{if(!isEmpty(pHead))	//判断是否为空链表{if(length(pHead)== 1) 	//判断有几个节点{popFront(pHead);}else{struct Node *p= pHead->next;while(p->next->next != NULL){p = p->next;}free(p->next);p->next = NULL;}}
}
链表销毁
void destroyList(struct Node *pHead)
{while(!isEmpty(pHead)){popBack(pHead);popFront(pHead);}
}

以上就是链表的常见操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/449373.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker exec命令流程

背景 在使用docker时,我们经常会使用docker的很多命令,比如docker exec等创建容器并执行命令,那么你知道这条命令背后的原理吗,本文就来解析下这条命令大致的执行流程图 docker exec命令 首先我们按照启动docker之后&#xff0…

集合的总结与复习

集合总结 1.1 什么是集合 集合可以看做是一个对象容器,可以存储很多个对象,管理多个对象及操作比较方便 1.2 集合与数组的区别 长度区别: 数组的长度是固定的而集合的长度是可变的; 存储数据类型的区别: 数组可以存储基本数据类型,也可以…

百无聊赖之JavaEE从入门到放弃(十八)其他常用类

目录 一.Math 类 二.Random 类 三.File类 四.枚举 一.Math 类 java.lang.Math 提供了一系列静态方法用于科学计算;常用方法如下: abs 绝对值 acos,asin,atan,cos,sin,tan 三角函数 sqrt 平方根 pow(double a, double b) a 的 b 次幂 max(double a,…

大数据分析|设计大数据分析的三个阶段

文献来源:Saggi M K, Jain S. A survey towards an integration of big data analytics to big insights for value-creation[J]. Information Processing & Management, 2018, 54(5): 758-790. 下载链接:链接:https://pan.baidu.com/s/1…

C++ pair+map+set+multimap+multiset+AVL树+红黑树(深度剖析)

文章目录 1. 前言2. 关联式容器3. pair——键值对4. 树形结构的关联式容器4.1 set4.1.1 set 的介绍4.1.2 set 的使用 4.2 map4.2.1 map 的介绍4.2.2 map 的使用 4.3 multiset4.3.1 multiset 的介绍4.3.2 multiset 的使用 4.4 multimap4.4.1 multimap 的介绍4.4.2 multimap 的使…

java处理ppt方案详解

需求 需要系统中展示的ppt案例有一个动态展示的效果,也就是要有动画的交互,要求支持浏览器直接打开预览 背景 目前已经实现了前端上传pptx文件,后端解析为png的图片,前端掉接口返回对应的图片,模拟播放ppt的效果 各种尝…

今天又接到了一个离谱的DEBUG订单

一、BUG程序 #include <iostream> #include <string>class Rectangle { private:int width;int height;public:Rectangle(int w, int h) {width w;height h;}void setWidth(int w) {width w;}void setHeight(int h) {height h;}int getArea() {return width *…

大数据应用开发3-Scala笔记1

一、编程框架 Scala语言是在JVM上运行的&#xff0c;兼容Java语法 区分大小写 - Scala是大小写敏感的&#xff0c;这意味着标识Hello 和 hello在Scala中会有不同的含义。 类名 - 对于所有的类名的第一个字母要大写。 如果需要使用几个单词来构成一个类的名称&#xff0c;每个…

【课程作业_01】国科大2023模式识别与机器学习实践作业

国科大2023模式识别与机器学习实践作业 作业内容 从四类方法中选三类方法&#xff0c;从选定的每类方法中 &#xff0c;各选一种具体的方法&#xff0c;从给定的数据集中选一 个数据集&#xff08;MNIST&#xff0c;CIFAR-10&#xff0c;电信用户流失数据集 &#xff09;对这…

【Springcloud篇】学习笔记五(十章):Gateway网关

第十章_Gateway新一代网关 1.Gateway简介 1.1官网 上一代zuul 1.X&#xff1a;https://github.com/Netflix/zuul/wiki 当前gateway&#xff1a;https://cloud.spring.io/spring-cloud-static/spring-cloud-gateway/2.2.1.RELEASE/reference/html/ 1.2是什么 SpringCloud …

MacOS安装JDK+Maven+Idea插件+nvm等

Java安装环境(MacOS)JDKMavenIdea插件nvm等 背景&#xff1a;新机安装开发环境发现需要找很多文章&#xff0c;&#xff0c;&#xff0c;&#xff0c;这里一篇文章安装所有环境 文章目录 Java安装环境(MacOS)JDKMavenIdea插件nvm等一、安装JDK①&#xff1a;下载②&#xff1a;…

【Qt5小项目】接金币小游戏

代码量在250行左右&#xff0c; 需要源码的可以私信我。