图及其应用一精.ppt
《图及其应用一精.ppt》由会员分享,可在线阅读,更多相关《图及其应用一精.ppt(80页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、图及其应用一第1页,本讲稿共80页一、一、图的基本概念图的基本概念1、图的的定义、图的的定义 图是由顶点图是由顶点V V的集合和边的集合和边E E的集合组成的二元组:的集合组成的二元组:记记G=G=(V V,E E)第2页,本讲稿共80页2、无向图和有向图、无向图和有向图无向图:无向图:在图在图G=G=(V V,E E)中,如果对于任意的)中,如果对于任意的a a,bVbV,当,当(a(a,b)Eb)E时,必时,必有(有(b b,a a)E E(即关系(即关系R R对称),对称图为无向图。对称),对称图为无向图。在一无向图中用不带箭头的边连接两个有关联的顶点。在一无向图中用不带箭头的边连接两个
2、有关联的顶点。V=V1,V2,V3,V4,V5E=(V1,V2),(V2,V3),(V3,V4),(V4,V5),(V5,V1),(V2,V5),(V4,V1)第3页,本讲稿共80页有向图:有向图:如果对于任意的如果对于任意的a a,bVbV,当,当(a(a,b)Eb)E时时 ,(b(b,a)Ea)E未必成立,则未必成立,则称此图为有向图。称此图为有向图。在有向图中,通常用带箭头的边连接两个有关联的结点。在有向图中,通常用带箭头的边连接两个有关联的结点。V=V1,V2,V3,V4 V=V1,V2,V3,V4 E=,E=,第4页,本讲稿共80页顶点的度:顶点的度:无向图:与顶点关联的边的数目。无
3、向图:与顶点关联的边的数目。有向图:等于该顶点的入度与出度之和。有向图:等于该顶点的入度与出度之和。入度入度以该顶点为终点的边的数目和以该顶点为终点的边的数目和出度出度以该顶点为起点的边的数目和以该顶点为起点的边的数目和 度数为奇数的顶点叫做奇点,度数为偶数的点叫做偶点。度数为奇数的顶点叫做奇点,度数为偶数的点叫做偶点。3 3、顶点的度、顶点的度第5页,本讲稿共80页 练习题练习题:1.1.假设我们用假设我们用d=(a1,a2,.,a5),d=(a1,a2,.,a5),表示无向图表示无向图G G的的5 5个顶点的度数,个顶点的度数,下面给出的哪(些)组下面给出的哪(些)组d d 值合理(值合理
4、()。)。A A)55,4 4,4 4,3 3,1 B1 B)44,2 2,2 2,1 1,1 C1 C)33,3 3,3 3,2 2,22 D D)55,4 4,3 3,2 2,1 E1 E)22,2 2,2 2,2 2,222.2.无向图无向图G G有有1616条边,有条边,有3 3个个4 4度顶点、度顶点、4 4个个3 3度顶点,其余顶点的度度顶点,其余顶点的度均小于均小于3 3,则,则G G至少至少_个顶点。个顶点。第6页,本讲稿共80页4 4、路径和连通集路径和连通集 在在图图G=G=(V V,E E)中中,如如果果对对于于结结点点a a,b b,存存在在满满足足下下述述条条件件的的
5、结点序列结点序列x x1 1xxk k(k1)(k1)x x1 1=a=a,x xk k=b=b (x(xi i,x xi+1i+1)E i=1E i=1k-1k-1则则称称结结点点序序列列x x1 1=a=a,x x2 2,x xk k=b=b为为结结点点a a到到结结点点b b的的一一条条路路径径,而而路路径径上上边边的的数数目目k-1k-1(或或者者沿沿路路径径各各边边权权值值之之和和)称称为为该该路路径径的的长长度度,并并称称结结点点集集合合xx1 1,x xk k 为连通集。为连通集。V1,v2,v5,v4第7页,本讲稿共80页5 5、简单路径和回路、简单路径和回路如如果果一一条条路
6、路径径上上的的结结点点除除起起点点x x1 1和和终终点点x xk k可可以以相相同同外外,其其它它结结点点均均不不相相同同,则则称称此此路路径径为为一一条条简简单单路路径径。图图(a)(a)中中v v1 1vv2 2vv3 3是一条简单路径,是一条简单路径,v v1 1vv3 3vv4 4vv1 1vv3 3不是简单路径。不是简单路径。x x1 1=x=xk k的的简简单单路路径径称称为为回回路路(也也称称为为环环)。例例如如图图(b)(b)中中,v v1 1vv2 2vv1 1为一条回路。为一条回路。第8页,本讲稿共80页例157324G26例245136G1路径:1,2,3,5,6,3路
7、径长度:5简单路径:1,2,3,5回路:3,5,6,3路径:1,2,5,7,6,5,2,3路径长度:7简单路径:1,2,5,7,6回路:1,2,3,1第9页,本讲稿共80页二、图的存储结构(教材二、图的存储结构(教材P79P79)图的邻接矩阵表示法图的邻接矩阵表示法 邻邻接接矩矩阵阵是是表表示示结结点点间间相相邻邻关关系系的的矩矩阵阵。若若G=G=(V V,E E)是是一一个个具具有有n n个个结结点的图,则点的图,则G G的邻接矩阵是如下定义的二维数组的邻接矩阵是如下定义的二维数组a a,其规模为,其规模为n*nn*n 1(1(或权值或权值)表示表示 顶点顶点i i和顶点和顶点j j有边有边
8、(i(i和和j j的路程的路程)Aij=Aij=0 0(或(或)表示顶点表示顶点i i和顶点和顶点j j无边无边 二维数组的行、列号表示顶点编号第10页,本讲稿共80页上图中的图上图中的图G G1 1和图和图G G2 2对应的相邻矩阵分别为:对应的相邻矩阵分别为:无向带权图的邻接(代价)矩阵表示有向无权图的邻接矩阵表示第11页,本讲稿共80页邻接矩阵的特点:邻接矩阵的特点:1)1)无向图的邻接矩阵是对称的,而有向图则不是。无向图的邻接矩阵是对称的,而有向图则不是。2)2)邻接矩阵方便度数的计算。用邻接矩阵表示图邻接矩阵方便度数的计算。用邻接矩阵表示图:(1)(1)容易判定任意两个结点之间是否有
9、边相联容易判定任意两个结点之间是否有边相联;(2)(2)容易求得各个结点的度数。容易求得各个结点的度数。对于无权无向图的邻接矩阵,第对于无权无向图的邻接矩阵,第i i行元素值的和就是行元素值的和就是ViVi的度的度数;数;对于无权有向图的邻接矩阵,第对于无权有向图的邻接矩阵,第i i行元素值的和就是行元素值的和就是ViVi的的出度,第出度,第i i列元素值的和就是列元素值的和就是ViVi的入度;的入度;对于有权无向图的邻接矩阵,第对于有权无向图的邻接矩阵,第i i行(或第行(或第i i列)中元素值列)中元素值00的元素个数就是的元素个数就是ViVi的度数;的度数;对于有权有向图的邻接矩阵,第对
10、于有权有向图的邻接矩阵,第i i行中元素值行中元素值00的元素个数的元素个数就是就是ViVi的出度;第的出度;第i i列元素值列元素值00的元素个数就是的元素个数就是ViVi的入度。的入度。第12页,本讲稿共80页例1452375318642各顶点的度是多少?0618360240120078400530750第13页,本讲稿共80页读入数据构造邻接矩阵(P80)n n竞赛题中一般图的数据是以这种方式给出的:竞赛题中一般图的数据是以这种方式给出的:n n题中会指定顶点数的最大值,以便于定义一个全局二维数组作为题中会指定顶点数的最大值,以便于定义一个全局二维数组作为邻接矩阵邻接矩阵n n数据文件的
11、第数据文件的第1 1行一般是图的顶点个数行一般是图的顶点个数N N以及边数以及边数MMn n接下来一般有接下来一般有MM行,每行有行,每行有2 2个或个或3 3个整数,描述了每条边的信息:个整数,描述了每条边的信息:如果是如果是2 2个整数个整数i i,j j,则一般表示顶点,则一般表示顶点i i和顶点和顶点j j有一条边相连有一条边相连 如果是如果是3 3个整数个整数i i,j j,k k,则一般表示顶点,则一般表示顶点i i和顶点和顶点j j相连的权值为相连的权值为k kn n针对图数据的这种结构,我们会用如下的代码来构造邻接矩阵:针对图数据的这种结构,我们会用如下的代码来构造邻接矩阵:第
12、14页,本讲稿共80页const int MAXN=201;/const int MAXN=201;/最大顶点数最大顶点数int aMAXNMAXN,n,m,i,j,k,x;int aMAXNMAXN,n,m,i,j,k,x;scanf(%d%d,&n,&m);scanf(%d%d,&n,&m);for(i=1;i=m;i+)/for(i=1;i=m;i+)/读入读入mm条边条边scanf(%d%d,&j,&k);scanf(%d%d,&j,&k);ajk=1;/ajk=1;/若是有向图,则只赋值若是有向图,则只赋值ajkajkakj=1;/akj=1;/若是无向图,则一定要赋值若是无向图,则
13、一定要赋值akjakj 如果是构造带权图,则上述如果是构造带权图,则上述for for 语句中的代码改为:语句中的代码改为:scanf(%d%d,&j,&k,&x);scanf(%d%d,&j,&k,&x);ajk=x;/ajk=x;/若是有向图,则只赋值若是有向图,则只赋值ajkajkakjl=x;/akjl=x;/若是无向图,则一定要赋值若是无向图,则一定要赋值akjakj第15页,本讲稿共80页邻接矩阵主对角线元素的处理n n在竞赛中很少有图数据是顶点带自环边的,因此邻接矩阵的在竞赛中很少有图数据是顶点带自环边的,因此邻接矩阵的主对角线元素主对角线元素aii(1=i=n)aii(1=i=
14、n)一般都是一般都是0 0。n n在前面讲的邻接矩阵的构造方法中,如果顶点在前面讲的邻接矩阵的构造方法中,如果顶点i i,j j之间没有边,则之间没有边,则aijaij也表示为也表示为0 0。在大多数图的算法中,不区别这两种值为。在大多数图的算法中,不区别这两种值为0 0的情况是可以的。的情况是可以的。n n而在某些图算法中,必须要区别主对角线元素和其它非主对角线而在某些图算法中,必须要区别主对角线元素和其它非主对角线元素,这时就用另外的特殊值来表示无边相连的情况。特殊值一元素,这时就用另外的特殊值来表示无边相连的情况。特殊值一般取一个很大的正数(或负数),实现实现代码如下:般取一个很大的正数
15、(或负数),实现实现代码如下:第16页,本讲稿共80页const int BIG=99999999;/const int BIG=99999999;/表示无穷大表示无穷大for(i=1;i=n;i+)/for(i=1;i=n;i+)/初始化初始化 for(j=1;j=n;j+)for(j=1;j=n;j+)aij=BIG;aij=BIG;aii=0;aii=0;for(i=1;i=m;i+)/for(i=1;i=m;i+)/读入边数据读入边数据scanf(%d%d%d,&j,&k,&x);scanf(%d%d%d,&j,&k,&x);ajk=x;ajk=x;akj=x;/akj=x;/这句无向
16、图才要这句无向图才要 邻接矩阵的优缺点见教材邻接矩阵的优缺点见教材P80P80判断判断i i,j j有无边相连:有无边相连:O(1)O(1)找找i i的邻接点,计算入度、出度:的邻接点,计算入度、出度:O(n)O(n)空间复杂性高:空间复杂性高:O(n2)O(n2)第17页,本讲稿共80页边集数组表示法(教材P80)n n一个一维数组存储图一个一维数组存储图n n每个元素表示一条边:起点、终点、权值(如果有的话)每个元素表示一条边:起点、终点、权值(如果有的话)n n适用于:对边进行依次处理的算法,适合存储顶点多但边很适用于:对边进行依次处理的算法,适合存储顶点多但边很少的稀疏图少的稀疏图n
17、n缺点:缺点:判断判断i i,j j有无边相连:有无边相连:O(E)O(E)找找i i的邻接点,计算入度、出度:的邻接点,计算入度、出度:O(E)O(E)n n优点:结构简单优点:结构简单第18页,本讲稿共80页边集数组表示法的实现const int MAXEDGE=2000;const int MAXEDGE=2000;struct node struct node int s,t;/int s,t;/边的起点和终点边的起点和终点int w;/int w;/边的权值边的权值 node edgeMAXEDGE;node edgeMAXEDGE;int n,m,i,j,k,x;int n,m,i
18、,j,k,x;scanf(%d%d,&n,&m);scanf(%d%d,&n,&m);for(i=1;i=m;i+)for(i=1;i=m;i+)scanf(%d%d%d,&j,&k,&x);scanf(%d%d%d,&j,&k,&x);edgei.s=j;edgei.s=j;edgei.t=k;edgei.t=k;edgei.w=x;edgei.w=x;第19页,本讲稿共80页邻接表表示法(P81)n n邻接表表示法是指对图中的每个顶点邻接表表示法是指对图中的每个顶点Vi(1=i=n)Vi(1=i=n)建立一个邻接关系的单链建立一个邻接关系的单链表,并把它们的表头指针用一维数组存储起来的一种
19、表示方法。表,并把它们的表头指针用一维数组存储起来的一种表示方法。n n为每个顶点为每个顶点ViVi建立的单链表,是表示以该顶点为建立的单链表,是表示以该顶点为起点起点的所有边的信息。以下图的所有边的信息。以下图(教材图(教材图5 52 2)为例,顶点)为例,顶点v1v1与与v2v2、v3v3、v5v5相邻,因此在相邻,因此在v1v1的单链表里就包含的单链表里就包含3 3条边的信息。条边的信息。v1v2v3v4v5524101183253853顶点v1的单链表有3个结点,表示有3条边与v1相接,有3个顶点(v2、v3、v5)是v1的邻接点不表示v2与v3相邻,v3与v5相邻第20页,本讲稿共8
20、0页邻接表表示法(P81)n n一维指针数组存储了每个顶点的单链表的头指针。一般就用数组下标表一维指针数组存储了每个顶点的单链表的头指针。一般就用数组下标表示了起点编号。例如示了起点编号。例如v1v1单链表的头指针就存储在单链表的头指针就存储在adj1adj1中。中。n n下图的完整邻接表如下所示:下图的完整邻接表如下所示:v1v2v3v4v552410118325385315325618225431051113265114103412345第21页,本讲稿共80页邻接表的数据结构const int MAXV=201;/const int MAXV=201;/最大顶点数最大顶点数struct
21、node struct node int v;/int v;/邻接点序号邻接点序号 int wt;/int wt;/权值,如果是带权图的话权值,如果是带权图的话 node*next;/node*next;/邻接单链表指针邻接单链表指针;node*adjMAXV;/node*adjMAXV;/每个顶点建一个单链表构造邻接表每个顶点建一个单链表构造邻接表int n,m;/nint n,m;/n表示读入的顶点个数,表示读入的顶点个数,mm表示读入的边条数表示读入的边条数第22页,本讲稿共80页创建邻接表void createlist()/void createlist()/创建邻接表创建邻接表 in
22、t i,j,k,x;int i,j,k,x;node*p;node*p;scanf(%d%d,&n,&m);/scanf(%d%d,&n,&m);/读入顶点数和边数读入顶点数和边数 for(i=1;i=n;i+)/for(i=1;i=n;i+)/初始化每个顶点的边表为初始化每个顶点的边表为NULLNULL adji=NULL;adji=NULL;for(i=1;i=m;i+)for(i=1;iv=k;/jp-v=k;/j的邻接点是的邻接点是k k p-wt=x;/p-wt=x;/边的权值是边的权值是x x p-next=adjj;/p-next=adjj;/新节点插在顶点新节点插在顶点j j的
23、边表的表头位置的边表的表头位置 adjj=p;adjj=p;/以下是无向图需要构造的对称边以下是无向图需要构造的对称边 p=new node;p=new node;p-v=j;/k p-v=j;/k的邻接点是的邻接点是j j p-wt=x;p-wt=x;p-next=adjk;/p-next=adjk;/新节点插在顶点新节点插在顶点k k的边表的表头位置的边表的表头位置 adjk=p;adjk=p;第23页,本讲稿共80页邻接表的优缺点(P82)n n便于查找后继顶点、以该点为起点的边、出度。便于查找后继顶点、以该点为起点的边、出度。n n不便于查找前趋顶点、以该点为终点的边、入度。解决办法:
24、不便于查找前趋顶点、以该点为终点的边、入度。解决办法:建立逆邻接表,即把以某顶点为终点的顶点放在一个单链表中。建立逆邻接表,即把以某顶点为终点的顶点放在一个单链表中。n n和邻接矩阵相比,构造邻接表的编程复杂性要高一些,但是查找后继和邻接矩阵相比,构造邻接表的编程复杂性要高一些,但是查找后继顶点的效率要高顶点的效率要高O(e/n)vs.O(n)O(e/n)vs.O(n)。如果边比较稀疏,显然用邻接。如果边比较稀疏,显然用邻接表存储图比较好。表存储图比较好。第24页,本讲稿共80页编程练习n n求一个有向图中指定顶点的出度。求一个有向图中指定顶点的出度。n n输入数据:第输入数据:第1 1行:行
25、:2 2个空格分开的整数个空格分开的整数n(2=n=200)n(2=n=200)和和m(10=m=20000)m(10=m=20000),分别表示图的顶点数和边数。,分别表示图的顶点数和边数。n n第第2.m+12.m+1行:每行行:每行2 2个空格分开的整数个空格分开的整数i i,j j,i i表示一条边的起点,表示一条边的起点,j j表示终点。表示终点。n n第第mm2 2行:行:1 1个整数个整数k(2=k=n),k(2=k=n),表示指定的顶点。表示指定的顶点。n n输出数据:第输出数据:第1 1行:行:1 1个整数个整数odod,表示顶点,表示顶点k k的出度。的出度。n n要求:分
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 及其 应用
限制150内