清北学堂—2020.1提高储备营—Day 3(图论初步(二))
qbxt Day 3
——2020.1.19 济南 主讲:李奥
目录一览
1.图论(kruskal算法,最短路径算法,拓扑排序)
总知识点:图论
一、kruskal算法
1.目的:求图的最小生成树
2.算法描述:
先将所有的边按照权值从小到大排序,相同权值的边顺序随意。
然后按顺序依次考虑将这些边加入最小生成树中:
若加入这条边后,当前已加入的边出现环,则不加入这条边。
若加入这条边后,当前已加入的边不出现环,则加入这条边。
3.代码实现:
qsort(a+1,m,sizeof(edge),cmp); //对边进行排序
for(i=1;i<=n;i++) belong[i]=i;
for(i=1;i<=m;i++){
if(belong[a[i].x]!=belong[a[i].y]){
ans+=a[i].k;
for(j=1;j<=n;j++){
if(belong[j]==belong[a[i].x])
belong[j]=belong[a[i].y];
}
}
}
二、最短路径
1.最短路径指所经过的边的权值最小的路径。(以下讨论主要针对有向图。)
2.算法:
(1)SPFA算法
解决问题:单元最短路
注:边权可以为负但不能有负环
最短路径的前缀也一定是最短路径
SPFA算法需要借助队列,一般使用STL中的队列。
注:STL的queue使用方法:
z.push() 在队列尾加入一个元素
z.pop() 弹出队列的队头
z.front() 取队头
z.empty() 判断队列非空
算法时间复杂度上限:O(N^N)(上限是相当慢的)
算法结构:
先固定一个起始节点s(d[i]表示起始节点s节点到节点i的目前已知的最短距离)。
最开始所有d[i]为inf,d[s]=0;(即什么都不知道)
有一个等待更新别人的d值的队列z
最开始只有s有资格更新别人,所以z.push(z)
每次取出队列里的第一个节点,用他的d值更新与他相邻的节点的d值,被更新的节点又有资格更新别人,因此也加入队列。
代码实现:
z.push(s);
v[s]=1;
while(!z.empty()){
x=z.front();
z.pop();
v[x]=0;
for(k=first[x];k;k=a[k].next){
y=a[k].y;
if(d[x]+a[k].k<d[y]){
d[y]=d[x]+a[k].k;
if(!v[y]){
z.push(y);
v[y]=1;
}
}
}
}
(2)Floyd算法
解决问题:所有节点之间的最短路
时间复杂度:O(n^3)
思想:
Dp :f[k][i][j]表示从i到达j,中途经过的节点的编号必须小于等于k的情况的最短路。
初始化f[0][i][j]即为邻接矩阵。
代码:
for(k=1;k<=n;k++)
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
f[k][i][j]=min(f[k-1][i][j],f[k-1][i][k]+f[k-1][k][j]);
//采用滚动数组:
for(k=1;k<=n;k++)
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
f[i][j]=min(f[i][j],f[i][k]+f[k][j]);
三、拓扑排序:
拓扑图:有向无环图
拓扑排序:
对于拓扑图的点进行排序,使得若有一条边x->y,则x一定排在y前面。
找到第一个节点之后,将这个节点从图中删除,重复直到原图的点全部被删除。
代码实现:
for(i=1;i<=n;i++){
if(d[i]==0)z.push(i);
}
while(!z.empty()){
x=z.front();
z.pop();
A[++len]=x;
for(k=first[x];k;k=a[k].next){
y=a[k].y;
d[y]--;
if(d[y]==0) z.push(y);
}
}
-------------------------------------------------------THE END------------------------------------------------
清北学堂—2020.1提高储备营—Day 3(图论初步(二))的更多相关文章
- 清北学堂—2020.1提高储备营—Day 4 afternoon(动态规划初步(一))
qbxt Day 4 afternoon --2020.1.20 济南 主讲:顾霆枫 目录一览 1.动态规划初步 2.记忆化搜索 3.递推式动态规划 4.记忆话搜索与递推式动态规划的转化 5.状态转移 ...
- 清北学堂—2020.1提高储备营—Day 4 morning(数论)
qbxt Day 4 morning --2020.1.20 济南 主讲:李奥 目录一览 1.一些符号与基本知识 2.拓展欧几里得,逆元与欧拉定理 3.线性筛法与积性函数(非重点) 总知识点:数论 一 ...
- 清北学堂—2020.1提高储备营—Day 3(图论初步(一))
qbxt Day 3 --2020.1.19 济南 主讲:李奥 目录一览 1.图论(图.图的存储方式.最小生成树的定义) 总知识点:图论 前言:众所周知,图论是一个非常重要的部分,而这次集训也可以算从 ...
- 清北学堂—2020.1提高储备营—Day 2 afternoon(线段树、树状数组)
qbxt Day 2 afternoon --2020.1.18 济南 主讲:李佳实 目录一览 1.线段树 2.二叉搜索树(略过) 3.树状数组 总知识点:基础数据结构(本人初学感觉好难) 一.线段树 ...
- 清北学堂—2020.1提高储备营—Day 1 morning(模拟、枚举、搜索)
qbxt Day 1 morning --2020.1.17 济南 主讲:李佳实 目录一览 1.模拟和枚举 2.基础搜索算法(DFS.BFS.记忆化搜索)以及进阶搜索算法(纯靠自学) 总知识点:基础算 ...
- 清北学堂—2020.1提高储备营—Day 2 morning(并查集、堆)
qbxt Day 2 morning --2020.1.18 济南 主讲:李佳实 目录一览 1.并查集 2.堆 总知识点:基础数据结构 一.并查集 1.描述:并查集是一类十分常用的数据类型,它有着十分 ...
- 清北学堂—2020.1提高储备营—Day 1 afternoon(二分、分治、贪心)
qbxt Day 1 afternoon --2020.1.17 济南 主讲:李佳实 目录一览 1.二分法 2.分治 3.贪心 总知识点:基础算法 一.二分法 (1)算法分析:二分法是一种暴力枚举的优 ...
- 清北学堂—2020.3NOIP数学精讲营—Day 1 morning 重点笔记
qbxt Day 1 morning 重点笔记 --2020.3.8 济南 主讲:钟皓曦 1 正数%负数==正数 负数%正数==负数 负数%负数==负数 a%b的答案的符号取决于a的符号. 2 快速幂 ...
- 清北学堂 2020 国庆J2考前综合强化 Day7
目录 1. 题目 T1 魔力石 题目描述 Sol T2 和 题目描述 Sol T3 数对 题目描述 Sol T4 海豹王国 题目描述 Sol 考场策略 1. 题目 T1 魔力石 题目描述 题目描述 小 ...
随机推荐
- Referer防盗链
一.目录展示 分为AProject和BProject两个项目进行测试 二.修改c:\windows\system32\drivers\etc下的hosts文件 三.aindex.jsp 四.binde ...
- [GPU高性能编程CUDA实战].(桑德斯).聂雪军等.扫描版-百度云分享
链接:https://pan.baidu.com/s/1NkkDiyRgmfmhm9d2g_GBKQ 提取码:3usj
- linux系统下gdb的简单调试
当我们写完程序后,我们会运行程序,在这个过程中,可能程序会出现错误. 我们可以利用gdb调试去看我们运行的程序,并且我们新手通过gdb调试能更好地去读懂 别人的程序.让我们更好的学习. 我们看下面这条 ...
- 4..部署场景2:带有遗留的Linux Bridge
此场景描述了使用Linux bridge的ML2插件实现OpenStack网络服务的遗留(基本)实现. 遗留实现通过为常规(非特权)用户提供一种方法来管理一个项目中的虚拟网络,并包含以下组件:提供了自 ...
- Request和Session的生命周期
request的生命周期是request请求域,一个请求结束,则request结束 session的生命周期是session会话域,打开一个浏览器请求一个网站的页面后,Session开始,当sessi ...
- AI: 如何用钢笔工具画曲线
AI 可以用来绘制矢量图片. 点击钢笔工具,点击画图会画出直线,点击拖拉画图会画出曲线. 锚点的摆放位置在侧面而非顶端. 控制柄越长,图形越尖锐. 画圆时控制柄长度控制在两点之间1/3 长度. 使用的 ...
- ARTS Week 4
标题: ARTS Week 4 分类: ARTS tags: ARTS ----------------------------------- Nov 18, 2019 ~ Nov 24, 2019 ...
- Mysql 5.7.18:主从复制,io优化
#目录 #挂盘#时间同步#master节点,进行如下操作: #下载安装 #初始化 #配置文件 #开机启动 #服务启动 #初始数据库#slave节点,进行如下操作: #下载安装 #初始化 #配置文件 # ...
- 检测并移除WMI持久化后门
WMI型后门只能由具有管理员权限的用户运行.WMI后门通常使用powershell编写的,可以直接从新的WMI属性中读取和执行后门代码,给代码加密.通过这种方式攻击者会在系统中安装一个持久性的后门 ...
- 3、实战:OutOfMemoryError异常
目的:第一,通过代码验证Java虚拟机规范中描述的各个运行时区域存储的内容:第二,工作中遇到实际的内存溢出异常时,能根据异常的信息快速判断是哪个区域的内存溢出,知道什么样的代码可能会导致这些区域内存溢 ...