数据结构之图(三)——邻接表

article/2025/8/27 22:35:06

邻接表表示法(链式)
在这里插入图片描述

  • 顶点: 按编号顺序将顶点数据存储在一维数组中。
  • 关联同一顶点的边: 用线性链表存储。
  • 如果有边\弧的信息,还可以在表结点中增加一项,
    在这里插入图片描述


无向图的邻接表

  • 例子:
    在这里插入图片描述

  • 特点:

    • 邻接表不唯一
    • 若无向图中有n个顶点、e条边,则其邻接表需要n个头结点和2e个表结点。适宜存储稀疏图。
    • 无向图中顶点 v i v_i vi的度为第i个单链表中的结点数。


有向图的邻接表

  • 例子:
    在这里插入图片描述

  • 邻接表特点:

    • 顶点 v i v_i vi出度为第i个单链表中的结点个数。
    • 顶点 v i v_i vi入度为整个单链表中邻接点域值是i-1的结点个数。
    • 找出度易,找入度难
  • 逆邻接表:
    在这里插入图片描述

  • 逆邻接表特点:

    • 顶点 v i v_i vi入度为第i个单链表中的结点个数。
    • 顶点 v i v_i vi出度为整个单链表中邻接点域值是i-1的结点个数。
    • 找入度易,找出度难
  • 当邻接表的存储结构形成后,图便唯一确定。



建立邻接表的算法

  • 图的邻接存储表示
    在这里插入图片描述
  • 顶点的存储结构
    在这里插入图片描述
    相应的类型定义如下,
typedef struct VNode
{VerTexType data;         //顶点信息ArcNode *firstarc;       //指向第一条依附该顶点的边的指针
}VNode,AdjList[MVNum];
  • 弧(边)的结点结构
    在这里插入图片描述
    相应的类型定义如下,
#define MVNum 100                //最大顶点数
typedef struct ArcNode           //边结点
{int adjvex;                  //该边所指向的顶点的位置struct ArcNode *nextarc;     //指向下一条边的指针OtherInfo info;              //和边相关的信息(权值等)
}ArcNode;
  • 图的结构定义
typedef struct
{AdjList vertices;      //存放各个顶点的数组int vexnum, arcnum;    //图的当前顶点数和弧数
}ALGraph;
  • 邻接表操作举例说明:
    在这里插入图片描述
ALGraph G;                    //定义了邻接表表示的图G
G.vexnum = 5; G.arcnum = 5;   //图G中包含5个顶点,5条边
G.vertices[1].data = 'b';     //图G中的第2个顶点是b
p = G.vertices[1].firstarc;   //指针p指向顶点b的第一条边结点
p->adjvex = 4;                //指针p所指边结点是到下标为4的结点的边
  • 采用邻接表表示法创建无向网
    • 算法思想:
      1.输入总顶点数和总边数。
      2.建立顶点表:依次输入点的信息存入顶点表中,使每个表头结点的指针域初始化为NULL。
      3.创建邻接表
      依次输入每条边依附的两个顶点
      确定两个顶点的序号i和j,建立边结点
      将此边结点分别插入到 v i v_i vi v j v_j vj对应的两个边链表的头部

    • 算法描述:

Status CreateUDG(ALGraph &G)
{cin >> G.vexnum >> G.arcnum;               //输入总顶点数,总边数for (i = 0; i < G.vexnum; ++i)             //输入各点,构造表头(顶点)节点表{cin >> G.vertices[i].data;             //输入顶点值G.vertices[i].firstarc = NULL;         //初始化表头结点的指针域}for (k = 0; k < G.arcnum; ++k)             //输入各边,构造邻接表{cin >> v1 >> v2;                       //输入一条边依附的两个顶点i = LocateVex(G, v1);j = LocateVex(G, v2);p1 = new ArcNode;                      //生成一个新的边结点*p1p1->adjvex = j;                        //邻接点序号为jp1->nextarc = G.vertices[i].firstarc;  G.vertices[i].firstarc = p1;           //将新结点*p1插入顶点vi的边表头部(头插法)p2 = new ArcNode;                      //生成一个新的边结点*p2p2->adjvex = i;                        //邻接点序号为ip2->nextarc = G.vertices[j].firstarc;G.vertices[j].firstarc = p2;           //将新结点*p2插入顶点vj的边表头部(头插法)}return OK;
}


邻接表表示法的优缺点

  • 优点:
    • 方便找任一顶点的所有“邻接点”
    • 节约稀疏图的空间:需要N个头指针+2E个结点(每个结点至少2个域)
    • 对无向图而言,方便计算任一顶点的度
  • 缺点:
    • 对有向图而言,只能计算“出度”,需要构造“逆邻接表”来方便计算“入度”。


邻接矩阵与邻接表表示法的关系

  • 联系:邻接表中每个链表对应于邻接矩阵中的一行,链表中结点个数等于一行中非零元素的个数。
    在这里插入图片描述

  • 区别:

    • 对于任一确定的无向图,邻接矩阵是唯一的(行列号与顶点编号一致),但邻接表不唯一(链接次序与顶点编号无关)。
    • 邻接矩阵的空间复杂度为 O ( n 2 ) O(n^2) O(n2),而邻接表的空间复杂度为 O ( n + e ) O(n+e) O(n+e)
  • 用途:邻接矩阵多用于稠密图;而邻接表多用于稀疏图。


http://chatgpt.dhexx.cn/article/8jw4mVqC.shtml

相关文章

邻接表

邻接表&#xff1a;所谓邻接表&#xff08;adjacency list&#xff09;&#xff0c;就是把从同一个顶点发出的边链接在同一个称为边链表的单链表中。边链表的每个结点代表一条边&#xff0c;称为边结点。每个边结点有2 个域&#xff1a;该边终点的序号&#xff0c;以及指向下一…

图的邻接表

邻接表 图的邻接表存储方法跟树的孩子链表示法相类似&#xff0c;是一种顺序分配和链式分配相结合的存储结构。如这个表头结点所对应的顶点存在相邻顶点&#xff0c;则把相邻顶点依次存放于表头结点所指向的单向链表中。如词条概念图所示&#xff0c;表结点存放的是邻接顶点在…

【数据结构】图的存储结构—邻接表

目录 什么是邻接表&#xff1f; 邻接表&#xff1a;定义 邻接表&#xff1a;相关类 邻接表&#xff1a;基本操作 1&#xff09;创建无向网 2&#xff09;创建有向网 3&#xff09;顶点定位 4&#xff09;插入边 5&#xff09;第一个邻接点 6&#xff09;查询下一个邻…

图的存储结构---邻接表

1. 邻接表&#xff08;无向图&#xff09; 对于边数相对顶点较少的图&#xff0c;可采取邻接表。把数组与链表结合在一起来存储&#xff0c;这种方式在图结构也适用&#xff0c;称为邻接表&#xff08;AdjacencyList&#xff09;。 2. 邻接表&#xff08;有向图&#xff09…

图的存储结构——邻接表

图的存储结构之邻接表 一、邻接表表示法无向图的邻接表有向图的邻接表有向图的逆邻接表 二、图的邻接表存储表示三、采用邻接表表示法创建无向网 一、邻接表表示法 回忆在线性表时&#xff0c;顺序存储结构就存在预先分配内存可能造成存储空间浪费的问题&#xff0c;于是引出了…

vivado实现FFT和IFFT信号处理

一&#xff0c;FFT的物理意义 FFT是离散傅立叶变换的快速算法&#xff0c;可以将一个信号变换到频域。有些信号在时域上是很难看出什么特征的&#xff0c;但是如果变换到频域之后&#xff0c;就很容易看出特征了。这就是很多信号分析采用FFT变换的原因。另外在频谱分析方面&a…

ifft java_OpenCV DFT_INVERSE与Matlab的ifft不同

我尝试使用opencv的dft函数过滤信号 . 我试图这样做的方式是在时域中获取信号&#xff1a; x [0.0201920000000000 -0.0514940000000000 0.0222140000000000 0.0142460000000000 -0.00313500000000000 0.00270600000000000 0.0111770000000000 0.0233470000000000 -0.00162700…

4.8 IFFT/FFT

4.8.1 IFFT/FFT原理 1. IFFT、FFT在OFDM系统中的应用 2、IFFT/FFT原理 3、DIT的基2FFT算法 4、DIF的基2FFT运算 5、基于的频率抽选FFT算法 4.8.2 基于 DIF FFT的硬件 结构 1、各级的蝶形运算硬件实现 2、transfer12、 transfer34、transfer56硬件实现 3、transfer23、 transfe…

Python实现FFT及IFFT

运行环境及编译工具 WindowsVS Code 编程语言及库版本 库版本Python3.7.0copy无numpy1.19.2opencv3.4.2PIL8.1.0matplotlib3.4.3 可执行文件 HW_2.pyHW_2.ipynb在HW_2.ipynb中执行&#xff0c;详细程序信息在HW_2.py中 问题 1 通过计算一维傅里叶变换实现图像二维快速傅里…

matlab FFT 和IFFT

代码&#xff1a; fs100;N128; n0:N-1;tn/fs; xsin(2*pi*40*t)sin(2*pi*15*t); subplot(221);plot(n,x,b); xlabel(时间/s);ylabel(x);title(原始信号); grid on;yfft(x,N); magabs(y); fn*fs/N; subplot(222);plot(f(1:N/2),mag(1:N/2)*2/N,b); xlabel(频率/Hz);ylabel(振幅)…

基于vivado实现FFT/IFFT

文章目录 前言一、基本过程二、vivado配置1.新建工程2.调用DDS的IP核2.调用FFT的IP核 三、编写Verilog程序1.顶层文件fft.v2.仿真文件fft_tb.v 四、运行仿真1. 运行仿真设置2. 仿真波形设置3. 结果分析 前言 使用vivado2018.3实现FFT&#xff0f;IFFT&#xff0c;过程比较详细…

python fft ifft

文章目录 条件代码实例 条件 任何一个满足狄利克雷条件的函数都可以通过傅里叶基数展开。 numpy和scipy中都有fft变换&#xff0c;且效果都是一样的。 代码 import numpy as np from scipy.fftpack import fft,ifft import matplotlib.pyplot as plt from matplotlib.pylab …

FFT专题:IFFT后信号如何重建

ifft(outFFTData, g_fft_temp, inFFTData, g_twiddle_ifft, twiddle_stride, F_WLEN);//思考ifft输出的复数结果怎么给到硬件输出 之前一直关注FFT后信号奔赴到频域处理,那么频域处理完后,怎么重建信号呢? 给出一段FFT和IFFT函数源码 int nFrameRunCount 0;#pragma section…

数字信号处理基础(二):FFT和IFFT的使用以及详细分析代码书写思路

目录 1. fft和ifft的原理1.1 fft1.2 ifft 2. 书写代码思路3. 完整代码4. 结果图 1. fft和ifft的原理 1.1 fft fft是快速傅里叶变换&#xff0c;是MATLAB中计算信号频谱的函数&#xff0c;使用方法是fft(x)&#xff0c;直接对信号x进行fft计算。 由于fft函数计算信号的频谱是0…

信号处理中的反傅里叶变换(IFFT)原理

信号处理中&#xff0c;经常需要将信号转换到频域进行分析&#xff0c;有时候还会从频域转回时域&#xff0c;用到FFT和IFFT函数。 FFT变换是将信号从时域转换到频域&#xff0c;在时域看起来复杂的信号转换到频域看起来就方便容易了很多。但有时候也需要将频域信号转换到时域…

adb下载、安装、环境配置

一&#xff1a;adb安装 adb下载链接&#xff1a;https://pan.baidu.com/s/1Vd6KyZ6vT2Qtmhazwre4OQ 提取码&#xff1a;3dx1 安装&#xff1a; 1.双击adb.exe文件&#xff0c;并运行。 2.添加环境变量&#xff1a; 右击计算机–属性—高级系统设置—高级—环境变量—新建&…

windows下载安装adb(极其简单)

单独安装adb&#xff0c;不安装sdk 下载adb Google很好的心&#xff0c;直接放出ADB的档案供人下载。下档路径如下&#xff1a; Windows版本&#xff1a;https://dl.google.com/android/repository/platform-tools-latest-windows.zip Mac版本&#xff1a;https://dl.google…

ADB-adb命令安装app

下载adb 安装adb 将名称中含有adb的文件&#xff0c;和fastboot.exe复制到 c:/windows/system32目录将名称中含有adb的所有文件复制到 c:/windows/system目录将adb.exe和AdbWinApi.dll复制到c:/windows/SysWoW64目录 有线安装apk 连接上数据线&#xff0c;然后把手机开发者模…

adb详细教程(一)-下载安装与环境变量配置

对于Android开发来说&#xff0c;adb是再熟悉不过的调试工具 但其实对于移动端的测试来说&#xff0c;adb也是一个十分重要的、能够提高测试工作效率的工具。 文章目录 一、介绍二、下载地址三、安装四、配置环境变量 一、介绍 全称 adb全称全称为Android Debug Bridge&#x…

mac下载安装adb环境

目录 方法一1、下载安装包2、下载完成后进行解压&#xff0c;目录路径注意不得包含中文3、配置环境变量4、验证安装是否成功 方法二1、安装homebrew2、安装adb3、运行adb 方法一 1、下载安装包 安装包下载地址 &#xff1a;https://developer.android.com/studio/releases/pl…