7-数据结构-(带头节点)单链表的增删改查

问题:

        单链表带头结点的创建以及输出,以及带与不带头节点的区别

思路:

  1. 单链表,逻辑上是线性结构,由许多单链表结点,串成一串。其单链表结构体中,数据项由data数据域和结点指针域。
  2. 带头节点是为了使在空表时的操作更统一。如果不带头节点,空表插入时,直接让头指针,和第一节点指针相等即可。而非空表插入时,则时s->next=l->next;l->next=s;头插,两个操作。而带上头节点,所有情况下的插入操作,都同意了即都为s->next=l->next;l->next=s。
  3. 值得注意的是,带头节点的单链表,遍历输出时,记得从第二哥结点开始遍历,即让结点指针=头指针的指针域。即snode*s =l->next;
  4. 在指针改变实际值时,C语言中,要么来哥双指针,要么正常一维指针,最后返回头指针,主函数内接收即可。我觉得为了好理解,就用返回这个吧,整那么花里胡哨,也挺乱的。嗯

头插法:

//创建带头节点的单链表
snode* sheadlist(linklist l,int n)
{snode *phead=l;      phead=(snode*)malloc(sizeof(snode));//创建头节点 phead->next=NULL;  int i=0,x=n,k=0;printf("请输入想要插入的值\n");for(i=0;i<x;i++){printf("输入第%d个值\n",i+1);scanf("%d",&k);snode *p=(snode*)malloc(sizeof(snode));p->data=k;p->next=phead->next;phead->next=p;}return phead;
} 

尾插法:

//创建带头结点尾插法 
linklist srearlist(linklist l,int x)
{snode* phead=l;//创建头节点phead=(linklist)malloc(sizeof(snode));//用头结点创造空间,指针l没有创建,因此返回的时候返回头节点 才能获取整个单链表地址 phead->next=NULL;int i,k;snode *end=phead;//工作指针,从头节点开始工作 printf("请输入值\n");for(i=0;i<x;i++){scanf("%d",&k);snode *p=(snode*)malloc(sizeof(snode));//创建新结点,用来尾插进单链表 p->data=k;end->next=p;//直接给新结点连接起来 end=p;      //因为尾插,所以要时刻知道最后一个结点的位置,因此s指针也跑到新加入的结点p上面. }end->next=NULL;	return phead;//头节点始终指向整个单链表,因此返回头节点地址,用来获取整个字符串 
} 

按位查找,返回结点:

//返回第i个结点指针
snode* Searchnode(snode* phead,int i)
{int count=1;//从有序数据,数组第一个开始计算snode* p=phead->next;if(i==0) return phead;//返回头节点if(i<0) return NULL;  //无效值while(p!=NULL && count != i)  //进行遍历,每一次进行比对,每次遍历指针后移{p=p->next;count++;}return p;	
} 

按值查找,返回位置:(根据不同的情况需求在while判断条件那里改变条件,进而求得想要的位置即可)

//按值查找,查找比x大的,并返回应插入的位置 
int Search_zhinode(snode* phead,int x)
{snode* p=phead->next;int count=1;while(x>p->data){p=p->next;count++;}return count;	
} 

在某个位置插入一个结点:(按位查找的妙用:

(用按位查找找到第i-1个结点,通过这个结点,进行操作))

//在某个位置插入一个结点 
snode* SInsert(snode* phead,int pos,int x)
{if(pos<1 || pos>SLength(phead)) return NULL;//进行插入操作snode* p=(snode*)malloc(sizeof(snode));p->data=x;//获取第pos-1个位置上的结点,在它后面插入 snode* ppre=Search_weinode(phead,pos-1);p->next=ppre->next;ppre->next=p;return phead;
}

计算带头结点单链表长度:

//计算单链表长度
int SLenth(snode* phead)
{if(phead==NULL) return 0;int count=1;snode* p =phead->next;//从有效数据第一个开始 while(p->next!=NULL){p=p->next;count++;}return count;} 

删除第i个结点:(用按位查找找到第i-1个结点,通过这个结点,进行操作)

//删除第i个结点 
snode* SDelete(snode* phead,int i,int *x)
{if(i<1 || i>SLenth(phead)) return NULL;snode* p =Search_weinode(phead,i-1);snode* q=p->next;*x=q->data;p->next=q->next;free(q);return phead;
}


 

代码如下:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
//创建带头结点单链表 
typedef struct snode
{int data;struct snode *next;
}snode,*linklist;
//创建带头节点的单链表
snode* sheadlist(linklist l,int n)
{snode *phead=l;      phead=(snode*)malloc(sizeof(snode));//创建头节点 phead->next=NULL;  int i=0,x=n,k=0;printf("请输入想要插入的值\n");for(i=0;i<x;i++){printf("输入第%d个值\n",i+1);scanf("%d",&k);snode *p=(snode*)malloc(sizeof(snode));p->data=k;p->next=phead->next;phead->next=p;}return phead;
} //创建带头结点尾插法 
linklist srearlist(linklist l,int x)
{snode* phead=l;//创建头节点phead=(linklist)malloc(sizeof(snode));//用头结点创造空间,指针l没有创建,因此返回的时候返回头节点 才能获取整个单链表地址 phead->next=NULL;int i,k;snode *end=phead;//工作指针,从头节点开始工作 printf("请输入值\n");for(i=0;i<x;i++){scanf("%d",&k);snode *p=(snode*)malloc(sizeof(snode));//创建新结点,用来尾插进单链表 p->data=k;end->next=p;//直接给新结点连接起来 end=end->next;      //因为尾插,所以要时刻知道最后一个结点的位置,因此s指针也跑到新加入的结点p上面. }end->next=NULL;	return phead;//头节点始终指向整个单链表,因此返回头节点地址,用来获取整个字符串 
} 
//返回第i个结点指针
snode* Search_weinode(snode* phead,int i)
{int count=1;snode* p=phead->next;//从头节点的后继节点开始遍历 if(i==0) return phead;if(i<0) return NULL;//遍历,当值小于查找值时,一直遍历,直到相等,count停止增加,此时便时所找位置处的结点,返回即可, while(p!=NULL && count != i){p=p->next;count++;}return p;	
} 
//按值查找,查找比x大的,并返回应插入的位置 
int Search_zhinode(snode* phead,int x)
{//默认单链表单调递增,因此从头遍历的话,看谁比x大,便找到了,主要画图清楚 snode* p=phead->next;int count=1;while(x>p->data){p=p->next;count++;}return count;	
} void slprintf(snode *s)
{if(s==NULL) return NULL; //空表 情况 snode *scan = s->next;//因为带头结点第一个结点为头节点,所以打印从第二个结点打印,因此这里需要注意 while(scan != NULL) {printf("%d->",scan->data);scan = scan->next;}                   printf("NULL\n");
}
//在某个位置插入一个结点 
snode* SInsert(snode* phead,int pos,int x)
{//进行插入操作//创建需要插入的结点,给结点赋值 snode* p=(snode*)malloc(sizeof(snode));p->data=x;//获取第pos-1个位置上的结点,在它后面插入 snode* ppre=Search_weinode(phead,pos-1);//进行插入操作 p->next=ppre->next;ppre->next=p;return phead;
}
//计算单链表长度
int SLenth(snode* phead)
{if(phead==NULL) return 0;int count=1;snode* p =phead->next;//从有效数据第一个开始 while(p->next!=NULL){p=p->next;count++;}return count;} 
//删除第i个结点 
snode* SDelete(snode* phead,int i,int *x)
{//判断插入合法性 if(i<1 || i>SLenth(phead)) return NULL;//找到删除结点的前驱结点 snode* p =Search_weinode(phead,i-1);//用按位查找,找到后返回前驱结点 //给q删除,因此先让q指针指向删除结点,取出值,随后p的指针域指向q的后继节点,最后给q释放。 snode* q=p->next;*x=q->data;//删除操作 p->next=q->next;free(q);return phead;
}int main()
{//创建头节点 snode* phead;
//	phead=sheadlist(&phead,3);//尾插法建立带头节点单链表 phead=srearlist(phead,5); //打印单链表 slprintf(phead);
//	snode *p=Searchnode(phead,2);//在有序的列表里面(默认有序),插入数值4,单链表仍有序 int pos=Search_zhinode(phead,4);printf("pos=%d\n",pos);//找到需要插入的位置后,进行在pos处的插入操作——即找到pos的前驱结点,之后进行插入 phead=SInsert(phead,pos,4);slprintf(phead);//计算单链表的长度 int len=SLenth(phead);printf("单链表长度为%d\n",len);//删除第4个结点,并返回删除结点的数值 int x=0;phead=SDelete(phead,4,&x);//因为需要给删除数值带回来,所以给x的地址传过去 printf("删除了%d\n",x);slprintf(phead);return 0;} 

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

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

相关文章

关于游戏的笔记

关于搭建秦时明月2一键端&#xff0c;并且开启秘境神秘商人东海寻仙幻化 1.该游戏下主要的目录 gm端 服务框架 服务端 2.修改对应的文件 C:\qs\Q2Server\server\conf_common\ManagerAddress.xmlC:\qs\Q2Server\server\conf_manager\GateServer.xml修改ip 3.启动gm startup…

零基础学习大数据需要什么基础么

大数据技术的体系庞大且复杂&#xff0c;每年都会涌现出大量新的技术&#xff0c;目前大数据行业所涉及到的核心技术主要就是&#xff1a;数据采集、数据存储、数据清洗、数据查询分析和数据可视化。 学习大数据需要掌握什么语言基础&#xff1f; 1、Java基础 大数据框架90%以…

阿里云官方关于数据安全保护的声明

“阿里云监控用户的数据流量&#xff1f;”“真的假的&#xff1f;”随着近日早晨 朱峰肥鹅旅行 对阿里云的一条朋友圈截图传遍了整个IT圈。 对于网络上的各种传播&#xff0c;以下是阿里云的官方答复&#xff0c;原文如下&#xff1a; 关于数据安全保护的声明 今天有客户反映…

【torchlars】windows下载github中的torchlars包遇到的问题及解决方案

环境 python3.7 windows10 cuda11.1 pytorch1.8.1 虚拟环境miniconda 目的 windows下载github中的torchlars包 遇到的问题 问题一&#xff1a;直接下载好文件夹输入指令&#xff1a;python setup.py install 出现错误&#xff1a;RuntimeError: Error compiling objects f…

opencv35-形态学操作-腐蚀cv2.erode()

形态学&#xff0c;即数学形态学&#xff08;Mathematical Morphology&#xff09;&#xff0c;是图像处理过程中一个非常重要的研 究方向。形态学主要从图像内提取分量信息&#xff0c;该分量信息通常对于表达和描绘图像的形状具有 重要意义&#xff0c;通常是图像理解时所使用…

oracle 自增id 和 更新时间戳

oracle 自增id 和 更新时间戳 需求 &#xff08;1&#xff09;需要让数据库插入数据时 I_ID 字段自增&#xff1b; &#xff08;2&#xff09;数据库更新数据后 S_LAST_UPDATETIME 字段更新当前时间 1、创建序列 CREATE SEQUENCE TABLENAME_I_ID_Sequence INCREMENT BY 1 S…

最佳路径优先搜索算法

本来想直接写A* 的&#xff0c;不过看完最佳路径优先搜索算法后觉得还是要先理解一下这个算法后才能更好的理解A* 算法&#xff0c;所以把这篇文章放到A* 前面。 基本概念 最佳优先搜索算法&#xff08;Best-first-searching&#xff09;是一种启发式搜索算法&#xff08;Heu…

Python实现GA遗传算法优化BP神经网络回归模型(BP神经网络回归算法)项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档视频讲解&#xff09;&#xff0c;如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 遗传算法&#xff08;Genetic Algorithm&#xff0c;GA&#xff09;最早是由美国的 John holland于20世…

Docker从零到掌握(详解)

目录 1.初识Docker 1.1 为什么使用docker 1.2 Docker技术 1.3.安装Docker 1.4.Docker架构 1.5.配置Docker镜像加速器 2.Docker常用命令 2.1.Docker服务相关的命令 2.2.Docker镜像相关的命令 2.3.Docker容器相关的命令 3. 容器的数据卷 3.1.数据卷的概念和作用 3.2…

Idea添加mybatis的mapper文件模版

针对Java开发人员&#xff0c;各种框架的配置模版的确是需要随时保留一份&#xff0c;在使用的时候&#xff0c;方便复制粘贴&#xff0c;但是也依然不方便&#xff0c;我们可以给开发工具&#xff08;IDE&#xff09;中添加配置模版&#xff0c;这里我介绍下使用idea开发工具&…

pip安装jupyter notebook

之前电脑安装了anaconda&#xff0c;里面安装了jupyter notebook&#xff0c;用来做PPT之类的展示总让我觉得有点“炫酷”。 现在换了新电脑。没有anaconda&#xff0c;纯粹只是装了python3.11&#xff0c;然后突然也想手工安装下jupyter notebook&#xff0c;于是只能通过pip方…

Python 中的机器学习简介:多项式回归

一、说明 多项式回归可以识别自变量和因变量之间的非线性关系。本文是关于回归、梯度下降和 MSE 系列文章的第三篇。前面的文章介绍了简单线性回归、回归的正态方程和多元线性回归。 二、多项式回归 多项式回归用于最适合曲线拟合的复杂数据。它可以被视为多元线性回归的子集。…

uniapp返回

// 监听返回事件onNavigationBarButtonTap() {uni.showModal({title: 提示,content: 确定要返回吗&#xff1f;,success: (res) > {if (res.confirm) {uni.navigateBack({delta: 2})}}})},

Opencv-C++笔记 (16) : 几何变换 (图像的翻转(镜像),平移,旋转,仿射,透视变换)

文章目录 一、图像平移二、图像旋转2.1 求旋转矩阵2.2 求旋转后图像的尺寸2.3手工实现图像旋转2.4 opencv函数实现图像旋转 三、图像翻转3.1左右翻转3.2、上下翻转3.3 上下颠倒&#xff0c;左右相反 4、错切变换4.1 实现错切变换 5、仿射变换5.1 求解仿射变换5.2 OpenCV实现仿射…

篇十:外观模式:简化复杂系统

篇十&#xff1a;“外观模式&#xff1a;简化复杂系统” 开始本篇文章之前先推荐一个好用的学习工具&#xff0c;AIRIght&#xff0c;借助于AI助手工具&#xff0c;学习事半功倍。欢迎访问&#xff1a;http://airight.fun/。 另外有2本不错的关于设计模式的资料&#xff0c;分…

力扣 -- 139. 单词拆分

一、题目 题目链接&#xff1a;139. 单词拆分 - 力扣&#xff08;LeetCode&#xff09; 二、解题步骤 下面是用动态规划的思想解决这道题的过程&#xff0c;相信各位小伙伴都能看懂并且掌握这道经典的动规题目滴。 三、参考代码 class Solution { public:bool wordBreak(str…

基于Java的新闻全文搜索引擎的设计与实现

中文摘要 本文以学术研究为目的&#xff0c;针对新闻行业迫切需求和全文搜索引擎技术的优越性&#xff0c;设计并实现了一个针对新闻领域的全文搜索引擎。该搜索引擎通过Scrapy网络爬虫工具获取新闻页面&#xff0c;将新闻内容存储在分布式存储系统HBase中&#xff0c;并利用倒…

当进行一个npm包开发时,依赖管理的重要性

npm install 的时候会进行什么&#xff1f; 当一个项目被拉下来并执行npm install的时候&#xff0c;其实dependencies 和 devDependencies都会被安装。 如果项目有严格区分生产、开发环境的话&#xff0c;是可以通过--production来以只安装 dependencies 字段的模块。 作为…

建筑行业如果应用了数字孪生技术能有什么改变?

数字孪生是一种将现实世界与数字世界相结合的先进技术&#xff0c;它在建筑行业中正发挥着越来越重要的作用。通过数字孪生技术&#xff0c;建筑行业可以实现从设计、施工到运营的全生命周期数字化管理&#xff0c;带来了许多优势和机遇。 ① 建筑设计阶段的应用 数字孪生能够…

Docker Compose: 集合管理Docker的工具安装

Docker Compose:集合管理多个Docker容器的工具&#xff0c;在安装docker时windows,macos默认安装Docker Compose&#xff0c;linux需要自己手动安装 去官网https://github.com/docker/compose/releases下载需要的版本$ sudo chmod x ./docker-compose-linux-x86_64$ sudo cp .…