• [2017.8.29 00:00]——前几天开始好好学了几天的图论,不过这最近又突然因为一些原因(其实是晚上没睡好导致白天没精神)颓废了几天…一方面为了控制自己同时也可以当做之后noip前复习用的笔记,毕竟自学党的笔记只能这样子了吧。嗯,尽量写一些比较有用的东西以后自己方便复习也方便给新人看(我自己不还是新人么x),除了图算法其他一些内容之后学到也尽量开个博客记一下…嗯大概就这样
  • 不定期更新
  • 如有错误还请指出!
  • 其实主要是留给自己用的,如果想要好好学的话还是去找比较具体的blog吧

想写的东西(大部分只留代码):

  • 图的表示/储存/访问
  • 强连通分量
  • 求最小生成树的的两种算法(K开头的那啥Kruskal跟Prim)
  • 单源最短路算法(Dij什么什么的和SPFA(Bellman-Ford队列优化))和多源最短路算法(Floyd)
  • 图的割点
  • 双联通分量(这个暂时还不会QAQ)
  • 拓扑排序
  • 欧拉路
  • 网络流相关 (开玩笑我怎么可能会网络流QwQ)
  • 一些基础的杂题

图的表示/储存/访问


  • 参考文献:算法导论

(话说这部分会比较基础觉得没问题的可以直接跳下去)(目前下面还没有)

如果比较严格的,一般记图\(G\)为一个二元组\(G=(V,E)\),其中\(V\)为有限集,称为图\(G\)的顶点集,\(V\)中的元素称为顶点。称为图\(G\)的边集,其元素称为。两个顶点相同的称为自环。对于有向图来说\(E\)由\(V\)中两个元素构成的二元关系,而无向图的边集\(E\)则是由无序的顶点对构成的,而不是有序对。

(下面还是不要用这么“严格”的说法好了,如果想看严格的说法可以参考算法导论

比如下图是一个顶点集为\(V=\{1,2,3,4,5,6\}\)边集为\(E=\{(1,1),(1,2),(1,3),(1,4),(2,4),(5,6),(6,5)\}\)的有向图的栗子



QwQ啊感觉这些概念不太好讲我也表达不清楚…概念部分就这样先过了吧x想了解的还是查其他的资料吧~

下面还是说说储存吧QwQ

我常用(或者可以说是用过的)的大概就两种…邻接矩阵链式前向星,我邻接表好像不怎么用…

  • 邻接矩阵:用一个矩阵\(A\)存图的边,比如可以用\(A[u][v]\)表示图中从\(u\)到\(v\)的一条边,边权就直接存在表中,不存在边一般就直接设为\(0\),\(∞\)或者是一些特殊值(具体根据实际情况)。这种表示方法可以快速查找两个点之间是否有边,以及如果有那么这条边的边权是多少,但如果有重边的话可能不太好处理,空间复杂度是\(O(n^2)\)。(目前我好像除了写Floyd以外基本没有用邻接矩阵…

  • 链式前向星:

    我们建一个结构体来表示权值为weight的边\((u,v)\):

      struct edge{int v,weight,next;};

    next表示这条边的下一条边的储存位置

    \(u\)呢?往下看x

    边集数组直接:

      edge Edges[M];

    加边只要设一个全局变量比如cnt,表示当前到第几条边

    一个head[]数组表示以i为起点第一条边的位置

    然后加一条\(u\)到\(v\)的权值为\(w\)的边就直接:

      void addEdge(int u,int v,int w)
    {
    Edges[++cnt]=(edge){v,w,head[u]};
    head[u]=cnt;
    }

    然后注意其实这样子head[i]实际上是输入的i为起点的最后一条边,也就是反过来的,不过这在大多数情况下并不会对结果造成影响。(嘛反正我是没遇到过)

    如果需要遍历以cur为起点的所有边可以:

      for(int i=head[cur];i;i=Edges[i].next)
    {
    //
    }

    这样Edges[i]就是当前这条边了,你可以对她做任何事情

    然后这一部分大概就这样…

    最后强调四点需要注意的:

    • 加边注意顺序不要错(不要像我一样把w放到next把head[u]放到w里面233)
    • 无向图边集数组要开题目范围的两倍空间!
    • 无向图边集数组要开题目范围的两倍空间!!
    • 无向图边集数组要开题目范围的两倍空间!!!

强连通分量


大概就是有向图中如果任意两个点\(u\)和\(v\)互相可达,那么我们就称这个图为强连通图。有向图中一个极大的强连通子图就被称为强连通分量

具体怎么求在这里不债述 (其实我也不怎么懂原理只会写模板)

有需要可以直接参考:BYVoid-有向图强连通分量的Tarjan算法

下面贴一下我平常的代码…大概长这样(临时打的不知道有没有打错…)

inline void tarjan(int i)
{
int j;
LOW[i]=DFN[i]=++Dindex;
stack[++s_top]=i;
inS[i]=1;
for(int cur=head[i];cur;cur=edges[cur].next)
{
j=edges[cur].to;
if(!DFN[j])
{
tarjan(j);
LOW[i]=min(LOW[i],LOW[j]);
}else if(inS[j])
LOW[i]=min(LOW[i],DFN[j]);
}
if(DFN[i]==LOW[i])
{
++cntscc;
do
{
j=stack[s_top]--;
inS[j]=0;
belong[j]=cntscc;
}while(i!=j);
}
}

(然后有没有人告诉我怎么证这个算法的正确性啊QAQ


丢一些模板先跑了x


因为开始正式上课了加上要准备开始学点新东西,剩下留着下次复习图论(如果有的话)再更吧

为了防止我老年痴呆症导致忘记怎么写一些模板…这里先贴几个模板(有空再来补充具体的说明)

丢模板逃x


如果有什么问题欢迎在评论区指出_(:з」∠)_

[OI笔记]基础图论/图算法的更多相关文章

  1. [OI笔记]杂题整理1(基础篇~)

    算是开学第四周啦,之前的三周大概过了一遍基础图论和数学相关的内容.这篇随笔打算口胡一些近期做感觉比较好的数学相关的题目 因为这段时间主要是看紫书学的,所以其实会有些出自UVA的例题,如果需要题目但是觉 ...

  2. Day 4 学习笔记 各种图论

    Day 4 学习笔记 各种图论 图是什么???? 不是我上传的图床上的那些垃圾解释... 一.图: 1.定义 由顶点和边组成的集合叫做图. 2.分类: 边如果是有向边,就是有向图:否则,就是无向图. ...

  3. jQuery学习笔记 - 基础知识扫盲入门篇

    jQuery学习笔记 - 基础知识扫盲入门篇 2013-06-16 18:42 by 全新时代, 11 阅读, 0 评论, 收藏, 编辑 1.为什么要使用jQuery? 提供了强大的功能函数解决浏览器 ...

  4. 小猪猪C++笔记基础篇(五)表达式、语句

    小猪猪C++笔记基础篇(五) 关键词:表达式.语句 本章的内容比较简单,基本上没有什么理解上的困难,都是知识上的问题.先开始想要不要写呢,本来是不准备写的,但是既然读了书就要做笔记,还是写一写,毕竟还 ...

  5. 小猪猪C++笔记基础篇(六)参数传递、函数重载、函数指针、调试帮助

    小猪猪C++笔记基础篇(六) ————参数传递.函数重载.函数指针.调试帮助 关键词:参数传递.函数重载.函数指针.调试帮助 因为一些事情以及自己的懒惰,大概有一个星期没有继续读书了,已经不行了,赶紧 ...

  6. 小猪猪C++笔记基础篇(四)数组、指针、vector、迭代器

    小猪猪C++笔记基础篇(四) 关键词:数组,Vector. 一.数组与指针 数组相信大家学过C语言或者其他的语言都不陌生,简单的就是同一个变量类型的一组数据.例如:int a[10],意思就是从a开始 ...

  7. Python学习笔记基础篇——总览

    Python初识与简介[开篇] Python学习笔记——基础篇[第一周]——变量与赋值.用户交互.条件判断.循环控制.数据类型.文本操作 Python学习笔记——基础篇[第二周]——解释器.字符串.列 ...

  8. 数论算法 剩余系相关 学习笔记 (基础回顾,(ex)CRT,(ex)lucas,(ex)BSGS,原根与指标入门,高次剩余,Miller_Rabin+Pollard_Rho)

    注:转载本文须标明出处. 原文链接https://www.cnblogs.com/zhouzhendong/p/Number-theory.html 数论算法 剩余系相关 学习笔记 (基础回顾,(ex ...

  9. 《python基础教程(第二版)》学习笔记 基础部分(第1章)

    <python基础教程(第二版)>学习笔记 基础部分(第1章)python常用的IDE:Windows: IDLE(gui), Eclipse+PyDev; Python(command ...

随机推荐

  1. 面试阿里,字节跳动90%会被问到的Java异常面试题集,史上最全系列!

    Java异常架构与异常关键字 Java异常简介 Java异常是Java提供的一种识别及响应错误的一致性机制. Java异常机制可以使程序中异常处理代码和正常业务代码分离,保证程序代码更加优雅,并提高程 ...

  2. 巧用Beyond Compare帮你更好校对文稿

    我们平常所说的校对工作,大多数指的是书本.文章出版前的对其进行的原稿比对工作.该工作要求极为细致,校对者需对文稿中的标点.编号.序号等细微部分进行认真比对,以保证出版物的质量.其实我们在日常的学习工作 ...

  3. 攻克弹唱第九课(如何运用好G大调和弦)

    在本期文章中,笔者将使用guitar pro7软件与大家分享如何运用好G大调音阶的经验. 众所周知,在我们学习吉他的过程中,先从C大调开始,再以G大调为深入,然后才走过入门的阶段.很多朋友都觉得自己对 ...

  4. guitar pro 系列教程(十七):Guitar Pro怎么导入音色库?

    前面的章节讲述了关于Guitar Pro相关功能的介绍以及使用,其中也有提到音色库,玩音乐的朋友都知道,音色库是一个乐器的必备,今天小编要跟大家讲的就是关于Guitar Pro音色库是如何导入进去的, ...

  5. 「LOJ 3153」 「JOI Open 2019」三级跳

    题面 LOJ 3153 solution 对于任意一对\(A,B\),若区间\([A,B]\)中存在一个数权值大于\(A\)或\(B\),则用这个数来替代\(A\)或\(B\)显然更优. 故只需要考虑 ...

  6. Vue—新版本router-view 与 keep-alive 的互动

    1. <keep-alive> 直接嵌套到 <router-view> 上会失效,正确写法: <router-view #="{ Component }&quo ...

  7. C++基础练习1

    1 /* 2 //读入一个双精度浮点数,保留12位小数输出这个浮点数. 3 #include<iostream> 4 #include <iomanip> 5 using na ...

  8. ABAP CDS-Part 1(ABAP CDS实体)

    文章翻译自Tushar Sharma的文章,转载请注明原作者和译者! 目录 预备条件 一.概述 二.ABAP CDS实体(CDS Entity) a.定义ABAP CDS Views b.ABAP C ...

  9. .Net Core AddTransient、AddScoped和AddSingleton的使用

    区别: AddTransient 每次service请求都是获得不同的实例,暂时性模式:暂时性对象始终不同,无论是不是同一个请求(同一个请求里的不同服务)同一个客户端,每次都是创建新的实例 AddSc ...

  10. 软件工程与UML第三次作业

    博客班级 软件工程与UML2班 作业要求 本次作业要求 作业目标 <给至少5名同学提他的代码issue并用博客记录;根据收到的issue修改自己的代码> 作业源代码 我的码云仓库 学号 & ...