线性结构常规操作(四)

定义存储结构(以单向链表为主)

对于链表的定义,通过结构体进行定义,包括两部分,一是数据域,另一个就是指针,用于指向下一个节点。

1,创建链表

定义链表:

struct nodesq{int data;//数据域,这里以int为例struct nodesq * netx;//指向自身类型的指针域
}

创建链表:栈式(往前/左走)、队列式(往后/右走)
一般创建链表是通过循环创建的,这里为了方便理解才这样创建的。

struct nodesq *p1,*p2,*p3;
p1 = new nodesq;
p1->date = a1;
p2 = new nodesq;
p2->date = a2;
//p2->next = p1;//栈式,即后来的当head
p1->next = p2;//队列式

如图所示:
在这里插入图片描述

2,链表的查询(按序号、按数据元素)

在这里插入图片描述
例如:找数据域为a3的节点(按数据元素查找)
首先,有头有尾成链才是链表;链表的查询是建立在已创建链表的基础上。
只需要查找p->data是不是a3即可,若不是,接着查找下一个,p=p->next;

head = p;//首先,将给定的head头指针赋值给指针p
while(p->data != a3){//若当前节点的数据域不是a3p = p->next;//进行下一个节点判断
}

例如:找序号为4的节点(按序号查找)
也就是查询4次即可。
首先,有头有尾成链才是链表;链表的查询是建立在已创建链表的基础上。
这里只需要定义一个变量wsq用于存储序号即可,通过自加操作,到达4,则停下即可。

head = p;//首先,将给定的head头指针赋值给指针p
int wsq=0;
while(wsq != 4){//若当前节点的数据域不是a3p = p->next;//进行下一个节点判断wsq++;//序号自加
}
3,链表的插入

在这里插入图片描述
例如:在a3之前插入数据域为a2‘的节点S
首先,有头有尾成链才是链表;链表的查询是建立在已创建链表的基础上。
在a3之前插入a2’,这里关键点在于:①找到a3前的一个节点a2,将新插入的a2‘数据域对应的节点S的next指向a3节点。②a2所在的节点的next指向a2’所在的节点S。

head = p;//首先,将给定的head头指针赋值给指针p
while(p->next->data != a3){//找a3前一个节点p = n->next;//没找到,指针找下一个节点
}//当结束循环之后,p指向a3上一个节点位置
S->next = p->next;//p->next此时为a3所在节点,赋值给S节点的next,即S节点的next指向a3所在节点,此时a2所在节点和S节点的next都指向a3所在的节点
p->next = S;//将a2所在的节点原本指向a3所在节点,给改成指向S节点

最终实现效果图如下:
在这里插入图片描述

4,链表的删除

在这里插入图片描述
例如:删除a3所在的节点
首先,有头有尾成链才是链表;链表的查询是建立在已创建链表的基础上。
删除a3所在的节点,需要找到a3所在的节点之前的一个节点,即a2所在的节点。然后,将a2所在的节点的next指向a3所在节点的下一个节点。

head = p;//首先,将给定的head头指针赋值给指针p
while(p->next->data != a3){//找a3前一个节点p = n->next;//没找到,指针找下一个节点
}//当结束循环之后,p指向a3上一个节点位置,即a2所在的节点
p->next = p->next->next;//p->next->next即a3所在节点的下一个节点,也就是a4所在的节点位置  赋值给  p->next也就是a2所在的节点的next

之后a3需要进行回收一下即可
最后的效果图如下:
在这里插入图片描述

5,链表的输出
p = head;
while(p != NULL){//全部挨个输出printf("%d",p->data);p = p->next;//找下一个节点
}
while(p->next != NULL){//最后一个节点不输出printf("%d",p->data);p = p->next;//找下一个节点
}
6,循环链表

在这里插入图片描述

7,双向链表

在这里插入图片描述

8,带头链表

在这里插入图片描述

9,无头链表

在这里插入图片描述

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

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

相关文章

ffplay分析 (暂停 / 播放处理)

《ffplay的数据结构分析》 《ffplay分析(从启动到读取线程的操作)》 《ffplay分析(视频解码线程的操作)》 《ffplay分析(音频解码线程的操作)》 《ffplay 分析(音频从Frame(解码后)队列取数据到…

源码 状态机_[源码阅读] 阿里SOFA服务注册中心MetaServer(1)

[源码阅读] 阿里SOFA服务注册中心MetaServer(1)0x00 摘要0x01 服务注册中心1.1 服务注册中心简介1.2 SOFARegistry 总体架构1.3 为什么要分层0x02 MetaServer2.1简介2.2 问题0x03 代码结构0x04 启动运行4.1 集成部署4.2 独立部署0x05 总体逻辑5.1 程序主体5.2 配置0x06 启动6.1…

HttpService远程校验

今天学了下HttpService,和大家分享一下。HttpService是用来读取远程数据的一个对象,数据格式为XML。 我做了一个登陆校验的功能,主要是通过HttpService将服务器端的用户数据得到,然后在客户端判断输入的用户名和密码是否存在。 主…

免费开源FTP Server软件FileZilla Server

很多朋友在实际应用中都可能需要用到FTP Server类的软件,这类软件有很多,比较知名的有Serv-U、G6等,这里向大家介绍一下FileZilla Server,Windows平台下一款不错的FTP Server软件,而且是免费的、开源的。 S…

ffplay分析 (seek操作处理)

《ffplay的数据结构分析》 《ffplay分析(从启动到读取线程的操作)》 《ffplay分析(视频解码线程的操作)》 《ffplay分析(音频解码线程的操作)》 《ffplay 分析(音频从Frame(解码后)队列取数据到…

android 代码设置 键盘适应_硬核软件,能在电脑上控制iPhone和Android手机

在电脑上控制手机大概已经不是什么新鲜操作,小米、华为都为自家手机和电脑的联动推出了同屏操作之类的功能,此外也可以通过开源软件Scrcpy来在Windows或者macOS上实现对安卓手机的控制,这些基本都只针对安卓手机。近期,奇客君发现…

ijkplayer 消息循环处理过程分析

ijkplayer 消息循环处理过程分析简介一、消息队列初始化1、 initWithContentURLString函数2、 ijkmp_ios_create函数3、 ijkmp_create函数二、消息队列的消息循环处理函数启动1、prepareToPlay函数2、ijkmp_prepare_async函数3、ijkmp_prepare_async_l函数4、ijkmp_msg_loop函数…

json解析对应的value为null_徒手撸一个JSON解析器

Java大联盟致力于最高效的Java学习关注作者 | 田小波cnblogs.com/nullllun/p/8358146.html1、背景JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。相对于另一种数据交换格式 XML,JSON 有着诸多优点。比如易读性更好,占用空间更少等。在 …

平院Python习题

在读写文件之前,用于创建文件对象的函数是( A )。 A. open B. create C. file D.folder 解析: open(file, mode‘r’, buffering-1, encodingNone, errorsNone, newlineNone, close…

搭建srs服务器(rtmp)

搭建srs服务器(rtmp) 目录:1、下载srs源码(从码云上):2、 切换到srs.oschina:3、 这里使用3.0版本:4、 切换到trunk:5、 编译:6、 启动:7、查看日志输出&…

2560介绍_炒股高手收益翻10倍,只因妙用这一招2560战法,看了都不亏了

(本文由公众号越声研究(yslc927yj)整理,仅供参考,不构成操作建议。如自行操作,注意仓位控制和风险自负。)选股是每个刚入市的新股民需掌握的技巧,通过资金选股了解资金流向,善用工具轻松选股,同时多留意行业…

rtmp协议分析(三次握手)

RTMP详细分析(Message 消息,Chunk分块) librtmp分析(发送数据包处理) librtmp分析(接收数据包处理) RTMP协议是Real Time Message Protocol(实时信息传输协议)的缩写,它是由Adobe公司提出的一种应 用层的协…

合并文件夹中子目录_01 Linux之统计文件夹中文件个数以及目录个数

案例分析:今天遇到了一个需要统计路径下目录个数的问题如果一个一个的去数会很麻烦,找到了一篇文章刚好提到这个,于是我将方法整理了一下。该方法的链接:Linux统计文件夹中文件个数以及目录个数_SG匚hang的博客-CSDN博客_linux统计…

关于Makefile,Makefile.in,Makefile.am,Configure功能及相互关系的问题

目录makefile写法1. 简介2. 上路之前3. 一个简单的例子4.说明:4.1、autoscan4.2、 configure.scan4.3、aclocal4.4、autoconf4.5、Makefile.am4.6、 automake4.7、Makefilemakefile写法 在 Unix 上写程式的人大概都碰过 Makefile,尤其是用 C 来开发程式…

西安理工大学863(转载)

原创:https://blog.csdn.net/mzj15101229871/article/details/107613162 (博主总结的很完整,很厉害,本人为了查看方便,才转载的。本人只是个小白~) 第一章 绪论 考试大纲 1)了解数据元素、数…

原理简介_消息通信的利器MQTT协议简介及协议原理

- 没用过但是必须得知道系列 -前言:相比于 XMPP, MQTT 的简单轻量受到了不少工程师的喜爱,从物联网到传统的消息服务,简单可依赖的 MQTT 到底为何让人如此着迷呢?MQTT 协议-MQTT 协议简介及协议原理MQTT(Me…

rtmp协议分析(Message 消息,Chunk分块)

RTMP详细分析(三次握手) librtmp分析(发送数据包处理) librtmp分析(接收数据包处理) 目录1、Message(消息)2、Chunking(Message 分块)2.1、 Basic Header(基本的头信息)2.1.1、Basic Header为1个字节时2.1.…

将Sharepoint Server 2010部署到WINDOWS 7

首先祝CNBLOGS上的筒子们新年快乐。Sharepoint 2010 BETA版发布已经有段时间了,总是感觉MS的步伐要比我们这些追逐他的人快很多,不过确实他的每一次革新总给我们带来了惊喜。 前几天报名参加了SHAREPOINT 2010 DAY 活动(详情),等待着1月16日体…

嵌入式实训-day1

完全复制一个文件的内容到另外一个文件 思路解析: 首先我这里使用了三个.c文件,分别是:yanyu.c、yanyu_old.c、yanyu_now.c 其中yanyu.c负责将yanyu_old.c中的内容读入到buff缓冲区中,然后再从buff缓冲区中将数据写入到yanyu_no…

计量经济学建模_浅谈统计学模型(兼计量经济学模型)

计量经济学模型是从统计学模型中衍生出来的,故将它们一并放在此处进行说明。实际上,很多人在很久之前就督促我写一篇统计学和计量经济学模型的文章,但我太懒惰,一直拖到现在,也是十分汗颜。先讲一些统计学上的基础故事…