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(图论初步(二))的更多相关文章

  1. 清北学堂—2020.1提高储备营—Day 4 afternoon(动态规划初步(一))

    qbxt Day 4 afternoon --2020.1.20 济南 主讲:顾霆枫 目录一览 1.动态规划初步 2.记忆化搜索 3.递推式动态规划 4.记忆话搜索与递推式动态规划的转化 5.状态转移 ...

  2. 清北学堂—2020.1提高储备营—Day 4 morning(数论)

    qbxt Day 4 morning --2020.1.20 济南 主讲:李奥 目录一览 1.一些符号与基本知识 2.拓展欧几里得,逆元与欧拉定理 3.线性筛法与积性函数(非重点) 总知识点:数论 一 ...

  3. 清北学堂—2020.1提高储备营—Day 3(图论初步(一))

    qbxt Day 3 --2020.1.19 济南 主讲:李奥 目录一览 1.图论(图.图的存储方式.最小生成树的定义) 总知识点:图论 前言:众所周知,图论是一个非常重要的部分,而这次集训也可以算从 ...

  4. 清北学堂—2020.1提高储备营—Day 2 afternoon(线段树、树状数组)

    qbxt Day 2 afternoon --2020.1.18 济南 主讲:李佳实 目录一览 1.线段树 2.二叉搜索树(略过) 3.树状数组 总知识点:基础数据结构(本人初学感觉好难) 一.线段树 ...

  5. 清北学堂—2020.1提高储备营—Day 1 morning(模拟、枚举、搜索)

    qbxt Day 1 morning --2020.1.17 济南 主讲:李佳实 目录一览 1.模拟和枚举 2.基础搜索算法(DFS.BFS.记忆化搜索)以及进阶搜索算法(纯靠自学) 总知识点:基础算 ...

  6. 清北学堂—2020.1提高储备营—Day 2 morning(并查集、堆)

    qbxt Day 2 morning --2020.1.18 济南 主讲:李佳实 目录一览 1.并查集 2.堆 总知识点:基础数据结构 一.并查集 1.描述:并查集是一类十分常用的数据类型,它有着十分 ...

  7. 清北学堂—2020.1提高储备营—Day 1 afternoon(二分、分治、贪心)

    qbxt Day 1 afternoon --2020.1.17 济南 主讲:李佳实 目录一览 1.二分法 2.分治 3.贪心 总知识点:基础算法 一.二分法 (1)算法分析:二分法是一种暴力枚举的优 ...

  8. 清北学堂—2020.3NOIP数学精讲营—Day 1 morning 重点笔记

    qbxt Day 1 morning 重点笔记 --2020.3.8 济南 主讲:钟皓曦 1 正数%负数==正数 负数%正数==负数 负数%负数==负数 a%b的答案的符号取决于a的符号. 2 快速幂 ...

  9. 清北学堂 2020 国庆J2考前综合强化 Day7

    目录 1. 题目 T1 魔力石 题目描述 Sol T2 和 题目描述 Sol T3 数对 题目描述 Sol T4 海豹王国 题目描述 Sol 考场策略 1. 题目 T1 魔力石 题目描述 题目描述 小 ...

随机推荐

  1. 线程池之 ThreadPoolExecutor

    线程池之 ThreadPoolExecutor + 面试题 线程池介绍 线程池(Thread Pool):把一个或多个线程通过统一的方式进行调度和重复使用的技术,避免了因为线程过多而带来使用上的开销. ...

  2. Docker应用部署实录(包含完善Docker安装步骤)

    Docker应用部署实录(包含完善Docker安装步骤) 前言 首先说一下这篇文章的来源.我之前接手的一个IOT项目,需要安装多个中控服务器.中控服务器需要安装RabbitMQ,Mysql,多个服务, ...

  3. VS2017/19 在更新之后,.net core项目出一个500的神奇错误

    先说症状: VS 更新升级之后,如果用的是 .net core 的项目的时候,当vs升级时,.net core的sdk或者runtime有跟着升级的话,项目发布之后,覆盖dll到服务器时,会出现这个错 ...

  4. Linux/UNIX编程:获取指定用户所有正在运行的进程ID和进程名

    先用系统函数 `getpwnam` 获得指定用户名的 UID,然后遍历 /proc/ 中所有 PID 目录,如果 /proc/PID/status 中的 UID 是输入用户名对应的 UID 则输出该 ...

  5. python 爬虫过程中出现:ConnectionResetError: [WinError 10054] 远程主机强迫关闭了一个现有的连接

    参考: https://blog.csdn.net/illegalname/article/details/77164521

  6. LAMP: 分布式 HTTP 2.4.25 + PHP 5.4.13 + MySQL 5.5.28 分离部署

    目录 A. 环境说明:B. 效果截图:C. HTTP编译安装D. MySQL二进制安装E. PHP源码编译安装F. PHP连接HTTPG. PHP支持扩展功能xcacheH. PHP连接MySQLI. ...

  7. 题解 CSP2019-J2T4【加工零件】

    这题我们要求的是啥呢?仔细读题可以发现,工人传送带的关系可以看成一个 \(n\) 个点和 \(m\) 条边的无向图,然后对于每组询问 \((a,L)\),其实就是问: \(1\) 到 \(a\) 有没 ...

  8. java代码之美(16) ---Java8 Optional

    Java8 Optional 一句话介绍Optional类:使用JDK8的Optional类来防止NullPointerException(空指针异常)问题. 一.前言 在我们开放过程中,碰到的异常中 ...

  9. 重读es6, 正确了解promise中catch的用法

    前言 在最近的项目中,用到了es6的promise语法,发现promise.prototype.catch 并不只是单单reject抛出的回调函数,所以今天做一些笔录,防止以后在项目中又碰到这样的问题 ...

  10. 《Head first设计模式》之适配器模式

    适配器模式将一个类的接口,转换成客户期望的另一个接口.适配器让原本接口不兼容的类可以合作无间. 我们周围的适配器 如果你需要在欧洲国家使用美国制造的笔记本电脑,你可能需要使用一个交流电的适配器. 你知 ...