1、1. 图论的基本概念,2. 最短路问题及算法,图论模型基础知识,3. 最小生成树及算法,4. 旅行售货员问题,1.图论的基本概念,1) 图的概念,2) 赋权图与子图,3) 图的矩阵表示,4) 图的顶点度,5) 路和连通,1) 图的概念,定义 一个图G是指一个二元组(V(G),E(G),其中:,其中元素称为图G的顶点.,组成的集合,即称为边集,其中元素称为边.,定义 图G的阶是指图的顶点数|V(G)|, 用,来表示;,2) E(G)是顶点集V(G)中的无序或有序的元素偶对,定义 若一个图的顶点集和边集都是有限集,则称,其为有限图. 只有一个顶点的图称为平凡图,其他的,所有图都称为非平凡图.,定义
2、若图G中的边均为有序偶对,称G为有向,边 为无向边,称e连接 和 ,顶点 和 称,连接,,称 为e的尾,称 为e的头.,若图G中的边均为无序偶对 ,称G为无向图.称,为e的端点.,既有无向边又有有向边的图称为混合图.,常用术语,1) 边和它的两端点称为互相关联.,2)与同一条边关联的两个端点称,为相邻的顶点,与同一个顶点,点关联的两条边称为相邻的边.,3) 端点重合为一点的边称为环,,端点不相同的边称为连杆.,4) 若一对顶点之间有两条以上的边联结,则这些边,称为重边,5) 既没有环也没有重边的图,称为简单图,常用术语,6) 任意两顶点都相邻的简单图,称为完全图. 记为Kv.,7) 若 , ,
3、且X 中任意两顶点不,,,相邻,Y 中任意两顶点不相邻,则称为二部图或,偶图;若X中每一顶点皆与Y 中一切顶点相邻,称为,完全二部图或完全偶图,记为 (m=|X|,n=|Y|),8) 图 叫做星.,2) 赋权图与子图,定义 若图 的每一条边e 都赋以,一个实数w(e),称w(e)为边e的权,G 连同边上的权,称为赋权图.,定义 设 和 是两个图.,1) 若 ,称 是 的一个子图,记,2) 若 , ,则称 是 的生成子图.,3) 若 ,且 ,以 为顶点集,以两端点,均在 中的边的全体为边集的图 的子图,称,为 的由 导出的子图,记为 .,4) 若 ,且 ,以 为边集,以 的端点,集为顶点集的图
4、的子图,称为 的由 导出的,边导出的子图,记为 .,3) 若 ,且 ,以 为顶点集,以两端点,均在 中的边的全体为边集的图 的子图,称,4) 若 ,且 ,以 为边集,以 的端点,集为顶点集的图 的子图,称为 的由 导出的,边导出的子图,记为 .,为 的由 导出的子图,记为 .,3) 图的矩阵表示,邻接矩阵:,1) 对无向图 ,其邻接矩阵 ,其中:,(以下均假设图为简单图).,2) 对有向图 ,其邻接矩阵 ,其中:,其中:,3) 对有向赋权图 , 其邻接矩阵 ,对于无向赋权图的邻接矩阵可类似定义.,关联矩阵,1) 对无向图 ,其关联矩阵 ,其中:,2) 对有向图 ,其关联矩阵 ,其中:,4) 图
5、的顶点度,定义 1) 在无向图G中,与顶点v关联的边的数目(环,算两次),称为顶点v的度或次数,记为d(v)或 dG(v).,称度为奇数的顶点为奇点,度为偶数的顶点为偶点.,2) 在有向图中,从顶点v引出的边的数目称为顶点,v的出度,记为d+(v),从顶点v引入的边的数目称为,v的入度,记为d -(v). 称d(v)= d+(v)+d -(v)为顶点v的,度或次数,定理,的个数为偶数,推论 任何图中奇点,5) 路和连通,定义1) 无向图G的一条途径(或通道或链)是指,一个有限非空序列 ,它的项交替,地为顶点和边,使得对 , 的端点是 和 ,称W是从 到 的一条途径,或一条 途径. 整,数k称为
6、W的长. 顶点 和 分别称为的起点和终点 ,而 称为W的内部顶点.,2) 若途径W的边互不相同但顶点可重复,则称W,为迹或简单链.,3) 若途径W的顶点和边均互不相同,则称W为路,或路径. 一条起点为 ,终点为 的路称为 路,记为,定义,1) 途径 中由相继项构成子序列,称为途径W的节.,2) 起点与终点重合的途径称为闭途径.,3) 起点与终点重合的的路称为圈(或回路),长,为k的圈称为k阶圈,记为Ck.,4) 若在图G中存在(u,v)路,则称顶点u和v在图G,中连通.,5) 若在图G中顶点u和v是连通的,则顶点u和v之,之间的距离d(u,v)是指图G中最短(u,v)路的长;若没,没有路连接u
7、和v,则定义为无穷大.,6) 图G中任意两点皆连通的图称为连通图,7) 对于有向图G,若 ,且 有,类似地,可定义有向迹,有向路和有向圈.,头 和尾 ,则称W为有向途径.,例 在右图中:,途径或链:,迹或简单链:,路或路径:,圈或回路:,2最短路问题及算法,最短路问题是图论应用的基本问题,很多实际,问题,如线路的布设、运输安排、运输网络最小费,用流等问题,都可通过建立最短路问题模型来求解.,最短路的定义,最短路问题的两种方法:Dijkstra和Floyd算法 .,1) 求赋权图中从给定点到其余顶点的最短路.,2) 求赋权图中任意两点间的最短路.,2) 在赋权图G中,从顶点u到顶点v的具有最小权
8、,定义 1) 若H是赋权图G的一个子图,则称H的各,边的权和 为H的权. 类似地,若,称为路P的权,若P(u,v)是赋权图G中从u到v的路,称,的路P*(u,v),称为u到v的最短路,3) 把赋权图G中一条路的权称为它的长,把(u,v),路的最小权称为u和v之间的距离,并记作 d(u,v).,1) 赋权图中从给定点到其余顶点的最短路,假设G为赋权有向图或无向图,G边上的权均非,负若 ,则规定,最短路是一条路,且最短路的任一节也是最短路,求下面赋权图中顶点u0到其余顶点的最短路,Dijkstra算法: 求G中从顶点u0到其余顶点的最短路.,1) 置 ,对 , , 且 .,2) 对每个 ,用,代替
9、 ,计算 ,并把达到这个最小值的,一个顶点记为 ,置,3) 若 ,则停止;若 ,则用 i+1 代,替i,并转2).,Dijkstra算法: 求G中从顶点u0到其余顶点的最短路.,1) 置 ,对 , , 且 .,2) 对每个 ,用,代替 ,计算 ,并把达到这个最小值的,一个顶点记为 ,置,3) 若 ,则停止;若 ,则用 i+1 代,替i,并转2).,Dijkstra算法: 求G中从顶点u0到其余顶点的最短路.,1) 置 ,对 , , 且 .,2) 对每个 ,用,代替 ,计算 ,并把达到这个最小值的,一个顶点记为 ,置,3) 若 ,则停止;若 ,则用 i+1 代,替i,并转2).,Dijkstra
10、算法: 求G中从顶点u0到其余顶点的最短路.,1) 置 ,对 , , 且 .,2) 对每个 ,用,代替 ,计算 ,并把达到这个最小值的,一个顶点记为 ,置,3) 若 ,则停止;若 ,则用 i+1 代,替i,并转2).,定义 根据顶点v的标号l(v)的取值途径,使 到v,的最短路中与v相邻的前一个顶点w,称为v的先驱,点,记为z(v), 即z(v)=w.,先驱点可用于追踪最短路径. 例5的标号过程也,可按如下方式进行:,首先写出左图带权邻接矩阵,因G是无向图,故W是对称阵,Dijkstra算法:求G中从顶点u0到其余顶点的最短路,设G为赋权有向图或无向图,G边上的权均均非负.,对每个顶点,定义两
11、个标记(l(v),z(v)),其中:,l(v) :表从顶点u0到v的一条路的权,z(v) :v的先驱点,用以确定最短路的路线.,l(v)为从顶点u0到v的最短路的权,算法的过程就是在每一步改进这两个标记,使最终,S:具有永久标号的顶点集.,输入: G的带权邻接矩阵 w(u,v),备用-将求最短路与最短路径结合起来:,算法步骤:,首先写出带权邻接矩阵,例 求下图从顶点u0到其余顶点的最短路,因G是无向图,故W是对称阵,见Matlab程序-Dijkstra.doc,2) 求赋权图中任意两顶点间的最短路,算法的基本思想,(I)求距离矩阵的方法.,(II)求路径矩阵的方法.,(III)查找最短路路径的
12、方法.,Floyd算法:求任意两顶点间的最短路.,举例说明,算法的基本思想,(I)求距离矩阵的方法.,(II)求路径矩阵的方法.,在建立距离矩阵的同时可建立路径矩阵R,(III)查找最短路路径的方法.,然后用同样的方法再分头查找若:,(IV)Floyd算法:求任意两顶点间的最短路.,例 求下图中加权图的任意两点间的距离与路径.,插入点 v1,得:,矩阵中带“=”的项为经迭代比较以后有变化的元素.,插入点 v2,得:,矩阵中带“=”的项为经迭代比较以后有变化的元素.,插入点 v3,得:,插入点 v4,得:,插入点 v5,得:,插入点 v6,得:,故从v5到v2的最短路为8,由v6向v5追溯:,由
13、v6向v2追溯:,所以从到的最短路径为:,见Matlab程序-Floyd.doc,3最小生成树及算法,1) 树的定义与树的特征,定义 连通且不含圈的无向图称为树常用T表示.,树中的边称为树枝. 树中度为1的顶点称为树叶.,孤立顶点称为平凡树.,平凡树,定理2 设G是具有n个顶点的图,则下述命题等价:,1) G是树( G无圈且连通);,2) G无圈,且有n-1条边;,3) G连通,且有n-1条边;,4) G无圈,但添加任一条新边恰好产生一个圈;,5) G连通,且删去一条边就不连通了(即G为最,最小连通图);,6) G中任意两顶点间有唯一一条路.,2)图的生成树,定义 若T是包含图G的全部顶点的子
14、图,它又是树,则称T是G的生成树. 图G中不在生成树的边叫做弦.,定理3 图G=(V,E)有生成树的充要条件是图G是连,通的.,证明 必要性是显然的.,(II)找图中生成树的方法,可分为两种:避圈法和破圈法,A 避圈法 : 深探法和广探法,B 破圈法,A 避圈法,定理3的充分性的证明提供了一种构造图的生,成树的方法.,这种方法就是在已给的图G中,每步选出一条边使它与已选边不构成圈,直到选够n-1条边为止. 这种方法可称为“避圈法”或“加边法”,在避圈法中,按照边的选法不同,找图中生成树的方法可分为两种:深探法和广探法.,a) 深探法,若这样的边的另一端均已有标号,就退到标号为,步骤如下:,i)
15、 在点集V中任取一点u,ii) 若某点v已得标号,检,端是否均已标号.,若有边vw之w未标号,则给,w代v,重复ii).,i-1的r点,以r代v,重复ii),直到全部点得到标号为止.,给以标号0.,查一端点为v的各边,另一,w以标号i+1,记下边vw.令,例用深探法求出下图10的一棵生成树,0,1,2,3,4,5,6,7,8,9,10,11,12,13,13,a) 深探法,0,1,2,3,4,5,6,7,8,9,10,11,12,步骤如下:,若这样的边的另一端均已有标号,就退到标号为,i) 在点集V中任取一点u,ii) 若某点v已得标号,检,端是否均已标号.,若有边vw之w未标号,则给,w代v
16、,重复ii).,i-1的r点,以r代v,重复ii),直到全部点得到标号为止.,给u以标号0.,查一端点为v的各边,另一,w以标号i+1,记下边vw.令,例用深探法求出下图10的一棵生成树,3,b)广探法,步骤如下:,i) 在点集V中任取一点u,ii) 令所有标号i的点集为,是否均已标号. 对所有未标,号之点均标以i+1,记下这些,iii) 对标号i+1的点重复步,步骤ii),直到全部点得到,给u以标号0.,Vi,检查Vi,VVi中的边端点,边.,例用广探法求出下图10的一棵生成树,1,0,1,2,2,1,3,2,1,2,2,3,4,标号为止.,3,b)广探法,步骤如下:,i) 在点集V中任取一
17、点u,ii) 令所有标号i的点集为,是否均已标号. 对所有未标,号之点均标以i+1,记下这些,iii) 对标号i+1的点重复步,步骤ii),直到全部点得到,给u以标号0.,Vi,检查Vi,VVi中的边端点,边.,例用广探法求出下图10的一棵生成树,1,0,1,2,2,1,3,2,1,2,2,3,4,标号为止.,显然图10的生成树 不唯一.,B 破圈法,相对于避圈法,还有一种求生成树的方法叫做“破圈法”. 这种方法就是在图G中任取一个圈,任意舍弃一条边,将这个圈破掉,重复这个步骤直到图G中没有圈为止.,例 用破圈法求出,下图的一棵生成树.,B 破圈法,例 用破圈法求出下图的另一棵生成树.,不难发
18、现,图的生成树不是唯一的 .,3) 最小生成树与算法,介绍最小树的两种算法: Kruskal算法(或避圈法)和破圈法.,A Kruskal算法(或避圈法),步骤如下:,1) 选择边e1,使得w(e1)尽可能小;,2) 若已选定边 ,则从,中选取 ,使得:,i) 为无圈图,,ii) 是满足i)的尽可能小的权,,3) 当第2)步不能继续执行时,则停止.,定理4 由Kruskal算法构作的任何生成树,都是最小树.,例10用Kruskal算法求下图的最小树.,在左图中 权值,最小的边有 任取一条,在 中选取权值,最小的边,中权值最小边有 , 从中选,任取一条边,会与已选边构成圈,故停止,得,中选取在中
19、选取,中选取 . 但 与 都,B破圈法,算法2 步骤如下:,1) 从图G中任选一棵树T1.,2) 加上一条弦e1,T1+e1中,立即生成一个圈. 去掉此,圈中最大权边,得到新,树T2,以T2代T1,重复2)再,检查剩余的弦,直到全,部弦检查完毕为止.,例11用破圈法求下图的最小树.,先求出上图的一棵生成树.,加以弦 e2,得到的圈v1v3v2v1,去掉最大的权边e2,得到一棵新,树仍是原来的树;,再加上弦e7,得到圈 v4v5v2v4,去掉最大的权边e6,得到一棵,新树;如此重复进行,直到全,全部的弦均已试过,得最小树.,4. 旅行售货员问题,定义设G=(V,E)是连通无向图,包含图G的每个,
20、顶点的路称为G的哈密尔顿路(Hamilton路或H路).,包含图G的每个顶点的圈,称为G的哈密尔顿圈,(或Hamilton圈或H圈).,含Hamilton圈的图称为哈密尔顿图(或Hamilton,图或H图).,旅行售货员问题或货郎担问题.,一个旅行售货员想去访问若干城镇,然后回,到出发地.给定各城镇之间的距离后,应怎样计划,他的旅行路线,使他能对每个城镇恰好经过一次,而总距离最小?,它可归结为这样的图论问题:在一个赋权完,全图中,找出一个最小权的H圈,称这种圈为最优圈.,但这个问题是NP-hard问题,即不存在多项式,时间算法.也就是说,对于大型网络(赋权图),目前还,没有一个求解旅行售货员问
21、题的有效算法,因此,只能找一种求出相当好(不一定最优)的解.,一个可行的办法 :,是先求一个H圈,然后适当,修改,以得到具有较小权的另,一个H圈.,定义 若对于某一对i和j,有,则圈Cij将是圈C的一个改进.,二边逐次修正法:,在接连进行一系列修改之后,最后得一个圈,不能,再用此方法改进了,这个最后的圈可能不是最优的,但是它是比较好的,为了得到更高的精度,这个,程序可以重复几次,每次都以不同的圈开始. 这种,方法叫做二边逐次修正法.,例对下图16的K6,用二边逐次修正法求较优H圈.,较优H圈:,其权为W(C3)=192,分析: 找出的这个解的好坏可用最优H圈的权,的下界与其比较而得出.即利用最小生成树可得最,优H圈的一个下界,方法如下:,设C是G的一个最优H圈,则对G的任一顶点v,C-v是G-v的路,也G-v是的生成树.如果T是G-v的,最小生成树,且e1是e2与v关联的边中权最小的两条,边,则w(T)+w(e1)+w(e2)将是w(C)的一个下界.,取v=v3,得G-v3的一,最小生成树(实线),其,权w(T)=122,与v3关联,的权最小的两条边为,w(T)+w(v1v3)+w(v2v3),=178.故最优H圈的权,v1v3和v2v3,故w(C),应满足178 w(C) 192.,再见,