Chapter 4 图
Chapter 4 图
.
1- 图的存储结构
无向图:对称
有向图:……
2- 图的遍历
1 深度优先搜索(DFS)
类似于二叉树的先序遍历
2 广度优先搜索(BFS)
类似于二叉树的层序遍历
3- 最小(代价)生成树(针对无向图)MST
1 Prim算法 O(|V2|)
只与顶点数有关,与边无关
2 Kruskal算法 O(|E|log|E|)
只与边数有关,与顶点数无关
//什么样的图最小生成树唯一?图中所有权值不相等。
4- 最短路径
1 Dijkstra O(|V2|)
单源最短路径
l 要找出所有节点的最短路径,需要对每一个结点用Dijkstra O(|V3|)
l 边上有负权值,不适用
2 Floyd O(|V3|)
求解任意一对顶点间的最短距离
l 允许带有负权值的边,但不允许有负权值边组成的回路
5- 拓扑排序 O(|V|+|E|)
1 AOV网
以顶点表示活动,以边表示活动的先后次序,且没有回路的有向图
2 对有向无环图的拓扑排序
可能不唯一:如果有多个入度为0的顶点,可任选一个输出
6- 关键路径
1 AOE网
活动在边上的网,与AOV网相比
相同点:都是有向无环图
不同点:AOE网边表示活动、有权值,表示活动持续时间。顶点表示事件,事件是图中新活动开始旧活动结束的标志。
AOV网边表示活动之间的相互关系,无权值,顶点表示活动。
l 只存在一个入度为0的点称为源点
求关键路径的步骤:
1 拓扑排序
2 事件Vk的最早发生时间Ve(k)
V1->Vi max
3 时间Vk的最迟发生时间Vl(k)
从后向前算 min = 后-max
4 活动ai的最早开始时间e(i)
边上首结点的Ve(k)
5 活动ai的最迟开始时间l(i)
边上尾结点的Vl(k)-ai
6 d = l(i) - e(i)
//可以通过加快那些在所有关键路径上的关键活动来缩短工期
//关键路径不唯一
注:
1- 邻接矩阵的空间复杂度O(|V2|)
2- 邻接表—方便找出所有邻边(不唯一)
邻接矩阵—给定的两个顶点是否存在边
3- 十字链表—有向图的链式存储
容易求得顶点的入度和出度
图的十字链表表示不唯一,但一个十字链表可以唯一确定一个图。
4- 邻接多重表是无向图的另一种链式存储结构
5- BFS借助一个辅助队列,空间复杂度是O(|V|)
邻接表O(|V|+|E|),邻接矩阵O(|V2|)
6- DFS借助一个栈,空间复杂度是O(|V|)
邻接表O(|V|+|E|),邻接矩阵O(|V2|)
7- 当各边权值相等时,广度优先算法可以解决单源最短路径问题。
8- Prim O(|V2|)
Kruskal O(|E|log|E|)
Dijkstra O(|V2|)
Floyd O(|V3|)
拓扑 O(|V|+|E|)
9- 最短路径一定是简单路径
10- 可以判断有向图是否有环:深度优先搜索,拓扑排序
Chapter 4 图的更多相关文章
- Chapter 7(图)
1.Prim算法生成最小生成树 //Prim算法生成最小生成树 void MiniSpanTree_Prim(MGraph G) { int min,i,j,k; int adjvex[MAXVEX] ...
- 【译】x86程序员手册13-第5章 内存管理
Chapter 5 Memory Management 内存管理 The 80386 transforms logical addresses (i.e., addresses as viewed b ...
- 《算法导论》习题解答 Chapter 22.1-5(求平方图)
一.邻接矩阵实现 思路:如果是邻接矩阵存储,设邻接矩阵为A,则A*A即为平方图,只需要矩阵相乘即可: 伪代码: for i=1 to n for j=1 to n for k=1 to n resul ...
- 《算法导论》习题解答 Chapter 22.1-3(转置图)
一.邻接表实现 思路:一边遍历,一边倒置边,并添加到新的图中 邻接表实现伪代码: for each u 属于 Vertex for v 属于 Adj[u] Adj1[v].insert(u); 复杂度 ...
- Android Programming: Pushing the Limits -- Chapter 7:Android IPC -- Messenger
Messenger类实际是对Aidl方式的一层封装.本文只是对如何在Service中使用Messenger类实现与客户端的通信进行讲解,对Messenger的底层不做说明.阅读Android Prog ...
- [转]第四章 使用OpenCV探测来至运动的结构——Chapter 4:Exploring Structure from Motion Using OpenCV
仅供参考,还未运行程序,理解部分有误,请参考英文原版. 绿色部分非文章内容,是个人理解. 转载请注明:http://blog.csdn.net/raby_gyl/article/details/174 ...
- PRML Chapter 2. Probability Distributions
PRML Chapter 2. Probability Distributions P68 conjugate priors In Bayesian probability theory, if th ...
- WITCH CHAPTER 0 [cry] 绝密开发中的史克威尔艾尼克斯的DX12技术演示全貌
西川善司的[WITCH CHAPTER 0 cry]讲座 ~绝密开发中的史克威尔艾尼克斯的DX12技术演示全貌 注:日文原文地址: http://pc.watch.impress.co.jp/d ...
- Chapter 3: Connector(连接器)
一.概述 Tomcat或者称之为Catalina(开发名称),可以简化为两个主要的模块,如下图: 多个Connector关联一个Container.之所以需要多个Connector,是为了处理多种协议 ...
随机推荐
- Windows中的"簇"和Linux中的"块"是对应的
扇区是对硬盘而言,块是对文件系统而言. 簇”又称为“分配单元” ,文件系统是操作系统与驱动器之间的接口,当操作系统请求从硬盘里读取一个文件时,会请求相应的文件系统(FAT 16/32/NTFS)打开文 ...
- Android开发 SeekBar开发记录
前言 开发记录博客不是讲解使用博客,更多的是各种功能与点子的记录 基本使用 <SeekBar android:layout_width="match_parent" andr ...
- INSTALL_FAILED_TEST_ONLY oppor11p 安装时出现的问题
刚开始出现这个问题 我很懵逼, 因为我之前一直运行都好好的 !!我在网上查了好多资料 试了好几种办法 我先说下我成功的办法 方法1: Android Studio 3.0会在debu ...
- 关于Cadence OrCad 16.6的破解
相信很多人都知道去老吴的博客上找安装包和破解文件,但是上面的自称一键式破解程序.以及破解图文说明,都是很有问题的. 首先,该一键式破解程序默认的文件后缀与该程序指向的安装压缩包后缀不一致:其次,该程序 ...
- C++——友元函数和友元类
友元函数:让函数可以访问类的私有属性 #include <iostream> using namespace std; class A { public: friend class B;/ ...
- Vue+Iview+Node 登录demo
1.相关组件安装 axios iview js-cookie crypto-js 2.子父组件传值.监听窗体大小改变.记住密码 .自定义组件(事件 .props) created:实例已经创建完 ...
- bootstrap1总结
bootstrap中的排版----标题: 标题(h1~h6/.h1~.h6) 副标题(small) h1:36px h2:30px h3:24px h4:18px h5:14px h6:12px 排版 ...
- webstorm 初次上传代码到 远程gitlab中
1. 在 公司搭建的gitlab网站,创建project,然后生成了 git的地址. 2.在 本地电脑上,打开 webstorm,要将已有的代码上传到 git网站,那么需要在webstrom编辑器的t ...
- 使用串口绘制实时曲线 —— SerialChart
SerialChart:下载 1. 实验效果 2. 串口程序 ){ ){ y = ; x = ; } ) y++; else y--; z = sin(x*Pi/); p = cos(x*Pi/); ...
- html自定义分页
public class MyPager { /// <summary> /// 每一页数据的条数 /// </summary> public int PageSize { g ...