循环链表2

循环链表的实现

对于数据结构中所有的结构而言,每一次都是用之前初始化(处理一开始的随机值)一下,

用完销毁(不管有没有malloc都能用,用了可以保证没有动态内存泄漏了)一下

而在C++里面,构造函数和析构函数就是解决这个问题的,

它说你不用每一次都做,它直接封装了这个初始化和销毁,它给你写好了,不用你每一次都自己写一遍了

初始化函数——挨个考虑

测试一下

初始化完的循环链表长这样

我们说的是链表的头结点的数据域是不用的

但也有人不想让其浪费了,就一开始让其制成0,plist->data=0;

然后每增加一个数据结点,就让plist->data++;同理删除就- -

以此来存放链表plist的有效数据长度length

后面要是需要求GetLength时,直接返回plist->data就可以了

这里就说明设计和实现是一一对应的

但如果他要这么用,则相应的插入和删除函数都要做出修改

头插函数

1.malloc申请结点p,val放进去

2.绑后面;p->next=plist->next;——>后面就是新申请(右边)的结点的next先按其顺序连线(也就是给p->next赋值),绑即=

3.绑前面plist->next=p;——>左边像后面顺序连接

只要用该指针的指向符,则该指针必须要用assert——有->就有assert

p->next=plist只适用于插入第一个数据,

后面的数据再插入时就会出错,例如当第二个有效数据元素进行头插时,先绑后面的,p->next被赋值为plist->next的值,而plist->next就是绑的后面一串数据

如果直接还是让p->next=plist,那就是直接让头插进去的数据元素跟头结点形成总共为2个结点的循环链表,丢掉了后面的一串数据,也就是后面的线没绑起来

然后每次都是让新插入的数据跟头结点形成新的循环链表,前面旧的数据结点就都丢失了

p->next=plist这句话之所以在只有一个头结点时插入第一个数据结点可以用,是因为此时这个第一个数据结点也就是最后一个数据结点了

而循环链表就是让数据结点的尾巴结点指向头结点plist,所以它p->next=plist只适用于头就是尾,尾就是头的总有效长度为1的头插

所以要用p->next=plist->next,它可以让第一个头插的结点绑向头结点,后面头插的结点绑住后面的元素线

可以发现其跟单链表里面的头插是一样的

这里先绑后面的,后面是空就绑空,是数据1的结点就绑1结点

现在来测试一下

先写一下输出函数

它跟单链表唯一不同的地方就是循环退出条件为p!=plist;在单链表里面所有数据结点走完一遍p就到NULL了;而在循环链表里面数据结点遍历完一遍又从尾巴返回头结点plist了,这里plist相当于原来的NULL的位置

如果这里继续写p!=NULL的话,就相当于进入无限死循环的打印了,循环链表里面的next没有NULL,所以循环链表里面不能写NULL,只要写NULL就是错误

尾插函数(考试重点)

由上图知,尾插中找尾巴的遍历p要初始化成plist,对应的终止条件为p->next!=plist

绑后面也可以这样写,因为q->next==plist(循环链表里面)

除了遍历终止条件不是空,其他跟单链表也是一样的

所以循环链表就是将单链表里面空的地方换成plist,没空不管,有空就换

测试

上面可以看到,头插是逆序,尾插是正序

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

激发创新,助力研究:CogVLM,强大且开源的视觉语言模型亮相

项目设计集合(人工智能方向):助力新人快速实战掌握技能、自主完成项目设计升级,提升自身的硬实力(不仅限NLP、知识图谱、计算机视觉等领域):汇总有意义的项目设计集合,助力新人快速实…

jdk9.0.1下载、安装、配置

下载路径xIndex of java-local/jdk/9.0.111 安装 环境变量配置 新增变量:JAVA_HOME 值:安装路径 path中新增:%JAVA_HOME%\bin

裸片-PCBA

裸片 PCBA, 薄膜, 邦定-COB(chip on board)技术是指将裸芯片直接贴在PCB 板上,然后用铝线或金线进行电子连接的技术

【软件工程师从0到1】- 封装 (知识汇总)

前言 介绍:大家好啊,我是hitzaki辰。 社区:(完全免费、欢迎加入)日常打卡、学习交流、资源共享的知识星球。 自媒体:我会在b站/抖音更新视频讲解 或 一些纯技术外的分享,账号同名:hi…

数据结构与算法实验(黑龙江大学)

实验一 顺序存储的线性表(2 学时) 一、实验目的 1 、掌握线性表的逻辑结构特征。 2、熟练掌握线性表的顺序存储结构的描述方法。 3 、熟练掌握顺序表上各种基本操作的实现。 二、实验内容 1 、设线性表的数据元素都为整数,存放在顺序表…

infercnv 三回首:深入理解infercnv为何能发nature

大家好,不知你是否还记得,前两次关于infercnv的介绍。请看这里: 肿瘤单细胞转录组拷贝数分析结果解读和应用 单细胞拷贝数变异 infercnv再回首 如果下载了示例数据,并且你已经跑了上述代码,不难得到这张图&#xff1…

基于Java GUI模拟银行自动取款机

一、课题描述 编写一个程序,模拟银行自动取款机的工作流程。主要功能如下所述: 当输入给定的卡号和密码(初始卡号为888888和密码为123456)时,系统能登录ATM柜员机系统,用户可以按照以下规则进行: 查询余额:初始余额为50000元 ATM取款:每次…

【LeetCode】每日一题 2023_11_21 美化数组的最少删除数(贪心/模拟)

文章目录 刷题前唠嗑题目:美化数组的最少删除数题目描述代码与解题思路 结语 刷题前唠嗑 LeetCode? 启动!!! 原本今天早上要上体育课,没那么早刷每日一题的,本周是体测周,所以体育课取消了&am…

二百零七、Flume——Flume实时采集5分钟频率的Kafka数据直接写入ODS层表的HDFS文件路径下

一、目的 在离线数仓中,需要用Flume去采集Kafka中的数据,然后写入HDFS中。 由于每种数据类型的频率、数据大小、数据规模不同,因此每种数据的采集需要不同的Flume配置文件。玩了几天Flume,感觉Flume的使用难点就是配置文件 二、…

Lightsail VPS 实例在哪些方面胜过 EC2 实例?

文章作者:Libai 引言 Lightsail VPS 实例和 EC2 实例是云计算领域中两种受欢迎的技术。虽然两者都提供虚拟服务器解决方案,但了解 Lightsail VPS 实例在哪些方面胜过 EC2 实例非常重要。在本文中,我们将探讨这两种技术之间的关键区别&#x…

FastReport在线设计器新版2024.1,新增多元素填充,条码元素拖放~

2024.1 版本中对报表设计器进行了更新!我们特别关注内部架构产品的变化,并提高了报告的视觉易用性。我们还添加了新的对象填充和渐变。 FastReport Online Designer下载(qun:585577353)https://www.evget.com/product/…

【深度学习】python调用超分Real-ESRGAN

Real-ESRGAN是超分自然场景图和动漫图,视频也可以,项目地址:https://github.com/xinntao/Real-ESRGAN/tree/master 安装python包: basicsr>1.4.2 facexlib>0.2.5 gfpgan>1.3.5 numpy opencv-python Pillow torch>1.…

姿态估计 手势动作实时识别项目(基于mediapipe、keras进行实现)

姿态估计 手势动作实时识别项目(基于mediapipe、keras进行实现) 0、功能展示1、项目原理介绍2、数据集采集脚本3、将采集到的动作数据集利用mediapipe库检测手部关键点信息,转换成数据信息保存到本地4、训练一个效果一般的随机森林分类器5、使用Kreas训练一个效果好点的全连…

软件产品生命周期(SDLC)四个阶段

软件产品生命周期:指软件产品研发全部过程、活动和任务的结构框架。 产品的生命周期一般包括四个阶段:引入期、成长期、成熟期和衰退期,在不同的阶段中,市场对产品的反应不同,其销售特点不同,因而产品管理的…

【linux】安装telnet

1 安装telnet-server yum -y install telnet-server 安装telnet yum -y install telnet 启动telnet服务 service xinetd restart 报错了: Redirecting to /bin/systemctl restart xinetd.service Failed to restart xinetd.service: Unit not found. 正在重定…

Dirac‘s BRA and KET notation

from kets to bras expansions the operater matrix elements adjoint of a linear operator Hermitian and Uniraty Operators Hermitian operator defination:

最前端|低代码平台轻松设计可视化图表【内含网站资源】

在前端设计中,我们经常需要使用可视化图表来呈现数据和信息。然而,每次都要自己从头开始设计图表未免太过繁琐。为了解决这个问题,我们调研了low code平台上的可视化图表功能。 本篇文章为大家带来以下问题的解答: (1&…

基于SSM的课程辅助教学平台的设计与实现

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:Vue 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目:是 目录…

MKRTOS MCU上的微内核操作系统

MKRTOS 全称是 Micro-Kernel Real-Time Operating System,中文名字是微内核实时操作系统。MKRTOS 是首款在开源的支持MCU的微内核操作系统。未来还将在MCU上支持虚拟化!!下载地址:https://gitee.com/IsYourGod/mkrtos-realMKRTOS被…

YOLOV5 人员检测项目【学习笔记(十一)】

这篇博客为修改过后的转载,因为没有转载链接,所以选了原创 文章目录 一、安装Pytorch 及 YOLO v51.1 安装GPU版 pytorch1.2 安装YOLO v5所需依赖 二、YOLO v5训练自定义数据2.1 标注数据2.1.1 安装labelImg2.1.2 标注 2.2 准备数据集2.2.1 组织目录结构…