24.8.3数据结构|双向循环链表、静态链表

server/2024/10/21 7:29:18/

双向循环链表

节点类型与双链表的节点类型完全相同双向循环链表的操作也与双链表的操作基本一致。

例题

将自然数一到N按由小到大的顺序沿顺时针方向围成一个圈,然后以一为起点先沿顺时针方向数到第N个数将其划去,再沿逆时针方向数到第K个数将其滑去,重复上述操作直到剩下一个数为止,问最后剩下的是哪个数。(用带头节点双向循环链表实现。)

静态链表

图示:

适用情况:

无法实现上述的链式存储但可以借用一维数组来实现的情况可以使用。

优点:

线性表的插入和删除操作时不需要移动元素,仅需要修改指针游标就行。具有链式存储的主要优点

主要函数:

1、定义结构

2、初始化:建立一个空的静态链表space(将一维数组space中各分量炼成一个备用链表零表示空指针根据当前地图)

3、获取结点函数:从备用链表上获取一个新的结点,如果备用连表已经空了,获取节点的操作失败

4、回收结点函数:将从链表中删除的结点插入到备用链表中的头结点之后

5、建立静态表:建立一个含有n个节点的静态链表head

6、求表长:计算静态链表head中数据元素的个数

7、取元素:取出静态链表head中的第i个结点的元素值

8、定位:确定静态链表head中第1个值为x

9、插入:在静态链表head的第i个结点之前插入一个值为x的新结点

10、删除:讲静态链表head中的第i个结点

11、输出:从头结点开始,依次输出静态链表head中的所有元素值。

 


http://www.ppmy.cn/server/95396.html

相关文章

JS 原型和原型链

构造函数 封装是面向对象思想中比较重要的一部分,js 面向对象可以通过构造函数实现的封装。 同样的将变量和函数组合到了一起并能通过 this 实现数据的共享,所不同的是 JS 借助构造函数创建出来的实例对象之间是彼此不影响的 存在浪费内存的问题&#…

网络基础命令配置复习 (基础华为设备)

目录 一.前言 二.Telnet远程登陆 2.1telnet介绍 2.2telnet的配置 三.交换机基础配置 四.致谢 一.前言 网络基础不仅是IT从业者的必备知识,也是日常生活中使用网络的人们应该了解的内容。通过学习和掌握这些基础知识,你将能更好地理解和利用现…

RocketMQ5.0消费者

RocketMQ 5.0 提供了三种主要的消费者类型:PushConsumer、SimpleConsumer 和 PullConsumer。每种类型的消费者都有其特定的使用场景和特点。以下是对这三种消费者的概念及其区别的详细阐述: PushConsumer 概念: PushConsumer 是一种主动推送…

Github 2024-08-03 Rust开源项目日报 Top10

根据Github Trendings的统计,今日(2024-08-03统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Rust项目10HTML项目1Go项目1Meilisearch: 快速搜索API,提升工作效率 创建周期:2252 天开发语言:Rust协议类型:MIT LicenseStar数量:44442 …

北京汽车美容元宇宙:数字化浪潮下的车美服务新革命

随着社会的发展和科技的进步,元宇宙这一概念正逐步渗透到人们的生活之中,改变了传统行业的运作模式。北京,作为科技创新的前沿城市,正见证着汽车美容元宇宙的诞生与兴盛,为车主们带来了全新的服务体验和便利。 ### 正…

AI学习指南机器学习篇-Sarsa算法的数学基础

AI学习指南机器学习篇-Sarsa算法的数学基础 在机器学习领域,Sarsa算法是一种经典的强化学习算法,它以其良好的收敛性和最优性条件而闻名。然而,了解Sarsa算法的数学基础对于深入理解其内在原理至关重要。本篇博客将探讨Sarsa算法背后的数学理…

laravel项目配置

创建laravel项目 composer create-project --prefer-dist laravel/laravel 项目名称生成项目key php artisan key:generate.清理配置缓存 php artisan config:clearlaravel生成代码 官网链接 php artisan make:model Flight --all生成Flight类相关的文件,对应数…

麦田物语第十八天

系列文章目录 麦田物语第十八天 文章目录 系列文章目录一、(Editor)制作 [SceneName] Attribute 特性二、场景切换淡入淡出和动态 UI 显示一、(Editor)制作 [SceneName] Attribute 特性 在本节课我们编写Unity的特性Attribute来更好的完善我们项目,具体是什么呢,就是当…