前面我们主要讲了数学规划问题,从这一部分开始我们进入下一部分:图和网络。
1.概论
图论起源于 18 世纪。第一篇图论论文是瑞士数学家欧拉于 1736 年发表的“哥尼斯堡的七座桥”。1847 年,克希霍夫为了给出电网络方程而引进了“树”的概念。1857年,凯莱在计数烷的同分异构物时,也发现了树的概念。近几十年来,由于计算机技术和科学的飞速发展,大大地促进了图论研究和应用,图论的理论和方法已经渗透到物理、化学、通讯科学、建筑学、运筹学,生物遗传学、心理学、经济学、社会学等学科中。
图论中所谓的“图”是指某类具体事物和这些事物之间的联系。如果我们用点表示这些具体事物,用连接两点的线段(直的或曲的)表示两个事物的特定的联系,就得到了描述这个“图”的几何形象。图论为任何一个包含了一种二元关系的离散系统提供了一个数学模型,借助于图论的概念、理论和方法,可以对该模型求解。哥尼斯堡七桥问题就是一个典型的例子。在哥尼斯堡有七座桥将普莱格尔河中的两个岛及岛与河岸联结起来,问题是要从这四块陆地中的任何一块开始通过每一座桥正好一次,再回到起点。
哥尼斯堡七桥问题
当然可以通过试验去尝试解决这个问题,但该城居民的任何尝试均未成功。欧拉为了解决这个问题,采用了建立数学模型的方法。他将每一块陆地用一个点来代替,将每一座桥用连接相应两点的一条线来代替,从而得到一个有四个“点”,七条“线”的“图”。问题成为从任一点出发一笔画出七条线再回到起点。欧拉考察了一般一笔画的结构特点,给出了一笔画的一个判定法则:这个图是连通的,且每个点都与偶数线相关联,将这个判定法则应用于七桥问题,得到了“不可能走通”的结果,不但彻底解决了这个问题,而且开创了图论研究的先河。
图与网络是运筹学(Operations Research)中的一个经典和重要的分支,所研究的问题涉及经济管理、工业工程、交通运输、计算机科学与信息技术、通讯与网络技术等诸多领域。下面将要讨论的最短路问题、最大流问题、最小费用流问题和匹配问题等都是图与网络的基本问题。
2.图与网络的基本概念
2.1.无向图
一个无向图(undirected graph)G是由一个非空有限集合和中某些元素的无序对集合组成的二元组,记为。其中称为图的顶点集(vertex set)或节点集(node set),中的每一个元素称为该图的一个顶点(vertex )或节点(node);称为图的边集(edge set),中的每一个元素(即中1某两个元素的无序对)记为或,,被称为该图的一条从到的边(edge)。
当边时,称是边的端点,并称与相邻;边称为与顶点关联,如果某两条边至少有一个公共端点,则这两条边在图中相邻。
边上赋权的无向图称为赋权无向图或无向网络,在这里对图和网络不做区分,因为任何图是可以赋权的。
如果一个图,它的顶点集和边集都有限,那么它被称为有限图。图的顶点数用符号或表示,边数用或表示。
当讨论的图只有一个时,总是用G来表示这个图。从而在图论符号中我们常略去字母,例如,分别用来代替。
端点重合为一点的边称为环。
如果一个图既没有环也没有两条边连接同一对顶点,那么这个图称为简单图。
2.2.有向图
定义:一个有向图G是由一个非空有限集合和中某些元素的有序对集合组成的二元组,即为。其中
称为图的顶点集和节点集,中的每一个元素称为该图的一个顶点或节点;称为图的弧集,中的每一个元素(即中某两个元素的有序对)记为或,或被称为该图的一条从到的弧。
当弧时,称为的尾,称为的头,并称为的出弧,为的入弧。
对应于每个有向图 D ,可以在相同顶点集上作一个图 G ,使得对于 D 的每条弧,G 有一条有相同端点的边与之相对应。这个图称为 D 的基础图。反之,给定任意图 G ,对于它的每个边,给其端点指定一个顺序,从而确定一条弧,由此得到一个有向图,这样的有向图称为 G 的一个定向图。
以下若未指明“有向图”三字,“图”均视为无向图。
2.3 完全图,二分图
对于每一对不同的顶点都有一条边相连的简单图称为完全图。个顶点的完全图记为。
二分图与完全二分图的解释若,,(这里表示集合中的元素个数),若此时中无相邻顶点对,中亦然,则称为二分图;特别地,若,则,则称为完全二分图,记为。
2.4 子图
如果,,则称图叫做图的子图,记做。若是的子图,则称为的母图。
特殊地,当时,图称为图的支撑子图。
2.5 顶点的度
设,中与关联的边数(每个环算作两条边)称为的度,记做。若是奇数,称是奇顶点:是偶数,称是偶顶点。关于顶点的度,我们有如下结论:
1.
2.任意一个图的奇顶点的个数是偶数。
2.6 图和网络的数据结构
网络优化研究的是网络上的各种优化模型与算法。为了在计算机上实现网络优化的算法,首先我们必须有一种方法(即数据结构)在计算机上来描述图与网络。一般来说,算法的好坏与网络的具体表示方法,以及中间结果的操作方案是有关系的。这里我们介绍计算机上用来描述图与网络的 5 种常用表示方法:邻接矩阵表示法、关联矩阵表示法、弧表表示法、邻接表表示法。在下面数据结构的讨论中,我们首先假设是一个简单有向图,,并假设中的顶点用自然数表示或编号,中的弧用自然数表示用编号。对于有多重边或无向网络的情况,将会在讨论完简单有向图的表示方法之后,给出说明。
2.6.1 邻接矩阵表示法
邻接矩阵表示法是讲图以邻接矩阵的形式存储在计算机中。图的邻接矩阵是如下定义的:
是一个的0-1矩阵,即:
例1 对于下面的有向图,用邻接矩阵表示法表示
例1图
直接写出邻接矩阵
2.6.2 关联矩阵表示法
关联矩阵表示法是将图以关联矩阵的形式存储在计算机中。图的关联矩阵是如下定义的:是一个的矩阵,即:
例2 对于例1的每条弧编号,从1到8分别是(1,2),(1,3),(2,4),(3,2),(4,3),(4,5),(5,3)和(5,4),则关联矩阵表示为:
2.6.3 弧表表示法
弧表表示法将图以弧表的形式存储在计算机中。所谓图的弧表,也就是图的弧集合中的所有有序对。弧表表示法直接列出所有弧的起点和终点,共需个存储单元,因此当网络比较稀疏时比较方便。此外,对于网络图中每条弧上的权,也要对应地用额外的存储单元表示。
例3 还是对于例1,用弧表表示法表示
弧编号 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
---|---|---|---|---|---|---|---|---|
起点 | 1 | 1 | 2 | 3 | 4 | 4 | 5 | 5 |
终点 | 2 | 3 | 4 | 2 | 3 | 5 | 3 | 4 |
权 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
2.6.4 邻接表表示法
邻接表表示法将图以邻接表(adjacency lists)的形式存储在计算机中。所谓图的邻接表,也就是图的所有节点的邻接表的集合;而对每个节点,它的邻接表就是它的所有出弧。邻接表表示法就是对图的每个节点,用一个单向链表列出从该节点出发的所有弧,链表中每个单元对应于一条出弧。为了记录弧上的权,链表中每个单元除列出弧的另一个端点外,还可以包含弧上的权等作为数据域。图的整个邻接表可以用一个指针数组表示。
链表举例
2.7 轨与联通
,其中与关联,称是图的一条道路,为路长,顶点和分别称为的起点和终点,而称为它的内部顶点。
若道路的边互不相同,则称为迹。若道路的顶点互不相同,则称为轨。
如果一个长度非0,起点和终点相同的道路,则称为闭合道路。起点和终点重合的轨称作圈。
若图的两个顶点间存在道路,则称联通。间的最短轨道长叫做间的距离。记做。若图的任二顶点均联通,则称是连通图。
显然有:
1.图是一条轨的充要条件是是联通的,且有两个一度的顶点,其余顶点的度是两度。
2.图是一个圈的充要条件是是各顶点的度均为2的联通图。
网友评论