0x13 链表与邻接表

0x13 链表与邻接表

数组是一种支持随机访问,但不支持在任意位置插入和删除元素的数据结构。与之相对应,链表支持在任意位置插入或删除元素,但只能按顺序依次访问其中元素。我们可以使用一个struct来表示链表的节点,其中可以存储任意数据。另外用prevnext两个指针指向前后两个相邻的节点,构成一个常见的双向链表。为了避免在左右两端或者空链表中访问越界,我们通常建立额外的两个节点headtail代表链表头尾,把实际数据节点存储在headtail之间,来减少链表边界处的判断,减低编程复杂度。

struct node{int value;node *prev,*next;
};
node *head,*tail;void initialize()
{head=new node();tail=new node();head->next=tail;tail->prev=head;
}
struct node{int val;int pre,next;
}nd[SIZE];
int head,tail,tot;void initialize()
{tot=2;head=1;tail=2;nd[head].next=tail;nd[tail].pre=head;
}

1.邻接表

在与链表相关的数据结构中,邻接表是相当重要的一种。它是图与树一般化存储方式,还能用于实现我们将在下一节中介绍的开散列Hash表。实际上,邻接表可以看成“带有索引数组的多个数据链表”构成的结构集合。在这样的结构中存储的数据被分为若干类,每一类的数据构成一个链表。每一类还有一个代表元素,称为该类对应链表的“表头”。所有的表头构成一个表头数组,作为一个可以随机访问的索引,从而可以通过表头数组定位到某一类数据对应的链表。

一个有n个点m条边的有向图,可以如此存储:

int tot;//边的总数
int ver[SIZE],edge[SIZE],next[SIZE],head[SIZE];
//分别记录每个边的终点,每个边的权值,把此边加入链表后的下一个边的序号,头结点指向的第一个边的序号//加入有向边(x,y),权值为z
void add(int x,int y,int z)
{ver[++tot]=y,edge[tot]=z;next[tot]=head[x],head[x]=tot;
}//访问从x出发的所有边
for(int i=head[x];i;i=next[i])
{int y=ver[i],z=edge[i];
}

例如插入6条边,顺序为(1,2),(2,3),(2,5),(3,5),(5,4),(5,1)。

在这里插入图片描述

对于无向图,我们可以把每条无向边看做两条有向边即可。我们可以利用第0x01学到的“成对变换”的位运算性质,程序开始时令tot=1,这样无向边便存储在veredge数组下标“2和3”,“4和5”…的位置上。通过对下标异或的操作,就可以直接定位到反向边。如果ver[i]是第i条边的终点,那么ver[i xor 1]则是第i条边的起点。

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

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

相关文章

数据标注常用的ChatGPT通用提示词模板

数据集理解:如何理解待标注的数据集? 标注规范制定:如何制定数据标注的规范? 标注工具选择:如何选择合适的数据标注工具? 数据预处理:如何对待标注数据进行预处理? 数据标注质量…

《师兄啊师兄》第二季开播 李长寿渡劫归来扬名四海

看新国风,上优酷动漫!由优酷出品,玄机科技制作,改编自阅文集团旗下起点读书小说《我师兄实在太稳健了》(作者:言归正传)的修仙喜剧动画《师兄啊师兄》第二季《海神扬名篇》于今日10:00正式回归。…

如何性能测试中进行业务验证?

在性能测试过程中,验证HTTP code和响应业务code码是比较基础的,但是在一些业务中,这些参数并不能保证接口正常响应了,很可能返回了错误信息,所以这个时候对接口进行业务验证就尤其重要。下面分享一个对某个资源进行业务…

[LGR-168-Div4]题解

比赛传送门 C,D,E,F题 《打水赛爱好者》 由于题目过水,所以A,B没有 C题 NK 题目描述 给定两个正整数 N , K N, K N,K,请你统计符合以下条件的正整数 x x x 的数量: 1 ≤ x ≤ N N 1 \leq x \leq N …

vue el-select 下拉框选择后,不显示

问题:下拉框数据是通过接口请求得到的, 通过change事件打印, select绑定的值和options的值,也能对应起来, 数据类型也一致, 排除了数据的原因, 应该就是视图没有更新了: 原因: 问过度娘后得知, 是因为数据层数太多, render函数没有更新, 解决方法: 1. 使用for…

【华为OD题库-089】整数编码

题目 题目描述 实现一个整数编码方法使得待编码的数字越小编码后所占用的字节数越小,编码规则如下 1.编码时7位一组,每个字节的低7位用于存储待编码数字的补码 2.字节的最高位表示后续是否还有字节,置1表示后面还有更多的字节,置0…

Python多线程threading的使用方法

前言 有时候,我们在编写Python程序时,会遇到比较耗时的函数方法,我们的需求是等这个耗时的函数执行完毕之后,在执行后面的程序,这时候就需要用到多进程。 下面我们来举一个使用多进程threading的例子 例子 import t…

Unity | AVpro的最基础使用方法(视频播放插件)

一、 AVpro的使用方法 (一)准备播放器MediaPlayer 1. AVpro的播放器是MediaPlayer,在Heirarchy面板里创建 2.播放器里放视频 a.把视频放到StreamingAssets文件夹下 b.你就可以在MediaPlayer里面找到这个视频 c.选中以后,就会变成 这里点击播放可以播放…

FET偏置控制器电路的卫星接收器LNB电路

都具有FET偏置控制器电路的卫星接收器LNB电路 芯片的描述:D3211是一-块用于卫星接收LNBs的专用电路,具有极化电压检测切换、22KHz脉冲检测切换和提供高放、本振级GaAs或HEMT FET晶体管工作点偏置等功能。D321 1内部的22K检测及切换控制由22K有源滤波器、…

RT-DETR改进《目标对象计数》多任务实验:深度集成版来了!支持自定义数据集训练自定义模型

💡该教程为改进RT-DETR专栏,属于《芒果书》📚系列,包含大量的原创改进方式🚀 💡🚀🚀🚀内含改进源代码 按步骤操作运行改进后的代码即可💡更方便的统计更多实验数据,方便写作 RT-DETR改进《目标对象计数》多任务实验:深度集成版来了!支持自定义数据集训练…

车联网助力自动驾驶发展

单车智能决策难点 芯片,成为自动驾驶的最大瓶颈 自动驾驶对芯片算力要求极高。要求自动驾驶处理器在每秒能够处理数百万亿次的计算; 自动驾驶对计算的实时性要求极高。任何一点时延,都有可能造成车毁人亡; 对低能耗有极大的…

Java并发编程基础总结

进程和线程概念 什么进程 进程是系统运行的基本单位,通俗的理解我们计算机启动的每一个应用程序都是一个进程。如下图所示,在Windows中这一个个exe文件,都是一个进程。而在JVM下,每一个启动的Main方法都可以看作一个进程。 什么…

Redis 中最常用的数据结构之一:String 数据类型介绍

Redis 大家好,我是香香。 在之前的 Redis 专栏 介绍与安装 Redis,高性能内存数据存储系统 我们介绍到了 Redis 支持多种数据结构,包括字符串、哈希表、列表、集合、有序集合等。 那我们今天来讲讲对 Redis 数据类型 String 的理解&#xff…

xtu oj 1214 A+B IV

题目描述 小明喜欢做ab的算术,但是他经常忘记把末位对齐,再进行加,所以,经常会算错。 比如1213,他把12左移了1位,结果变成了133。 小明已经算了一些等式,请计算一下他到底移动了多少位。 输入…

如何用gpt改写文章 (1) 神码ai

大家好,今天来聊聊如何用gpt改写文章 (1),希望能给大家提供一点参考。 以下是针对论文重复率高的情况,提供一些修改建议和技巧: 如何用GPT改写文章 一、引言 随着人工智能技术的飞速发展,自然语言处理领域取得了重大突…

【数电笔记】54-或非门构成的基本RS触发器

目录 说明: 1. 电路组成 2. 逻辑功能 3. 特性表 4. 特性方程 5. 例题 6. 两种基本RS触发器的形式比 说明: 笔记配套视频来源:B站;本系列笔记并未记录所有章节,只对个人认为重要章节做了笔记;标题前…

Event Bus设计模式

EventBus是消息中间件的设计思想,在此设计中有三个非常重要的角色(Bus、Registry、Dispatcher),Bus主要负责提供给外部使用的操作方法;Registry注册表用来整理记录所有注册在EventBus上的Subscriber;Dispat…

02-详解请求路由的实现和常见的断言工厂

请求路由 路由转发 第一步: 新建一个SpringBoot工程如gateway模块, 引入网关依赖和nacos服务发现依赖 <!--网关依赖--> <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId&…

玄关柜和鞋柜是一回事吗?福州中宅装饰,福州装修

玄关柜和鞋柜虽然都用于存放鞋子&#xff0c;但它们在概念上有所不同。玄关柜是一个更大的概念&#xff0c;它包括鞋柜和其他功能区域&#xff0c;可以说鞋柜是玄关柜的一部分。 1️⃣概念上的不同 玄关柜是一种集成了鞋柜、挂衣架、换鞋凳等多种功能于一体的家居家具&#xf…

Nginx(四层+七层代理)+Tomcat实现负载均衡、动静分离

一、Tomcat多实例部署 具体步骤请看我之前的博客 写文章-CSDN创作中心https://mp.csdn.net/mp_blog/creation/editor/134956765?spm1001.2014.3001.9457 1.1 访问测试多实例的部署 1.2 分别在三个tomcat服务上部署jsp的动态页面 mkdir /usr/local/tomcat/webapps/test vim …