首先是图的基本概念和图的遍历之类的基本操作。
几个模块,首先是最短路。
最短路的复杂度比较低,优化后可以求几十万的数据规模。
数学模型是类似差分约束的不等式最优化模型,每个边只有选和不选2种情况。
一些模型建图比较玄妙,比如为一个点集加入出点入点,或者求边数最少的路里的最短路,可以把每个边权加一个足够大的值,求出最短路除以这个值就是边数,取模就是最短路长度。
连通性:
线性的复杂度。简单的题目是只要缩点就行(特点是这些问题只要把环去掉就很容易解)。
更多问题是先缩点以变成无环图,再在图上进行操作(比如dp(动态规划是不能有环的),其他要求无环的图论算法)。
网络流:(需要智力的专题...):
主要是最大流和费用流。最大流复杂度至少是n^3的。求不过1000的规模。
但模型建立学问很多..因为数学模型相比最短路适用的更广,每个边是一个限制,但每个边可以只走一部分流量(最短路相当于全走