第5章 图的搜索算法PPT讲稿.ppt
《第5章 图的搜索算法PPT讲稿.ppt》由会员分享,可在线阅读,更多相关《第5章 图的搜索算法PPT讲稿.ppt(137页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第5章图的搜索算法第1页,共137页,编辑于2022年,星期一5.1图搜索概述图搜索概述第2页,共137页,编辑于2022年,星期一1显式图与隐式图显式图与隐式图 在路径问题、连通性问题、可平面性检验、着色问在路径问题、连通性问题、可平面性检验、着色问题和网络优化等问题中,图的结构是显式给出的,包括题和网络优化等问题中,图的结构是显式给出的,包括图中的顶点、边及权重,这类图我们称为图中的顶点、边及权重,这类图我们称为显式图显式图,也就,也就是一般意义上的图。是一般意义上的图。隐式图隐式图是由问题的初始结点,为了求解或求证问题,是由问题的初始结点,为了求解或求证问题,根据题目的规则(一般是由题目
2、的意思隐含给出的),也根据题目的规则(一般是由题目的意思隐含给出的),也就是生成子结点的约束条件,逐步扩展结点,直到得到目就是生成子结点的约束条件,逐步扩展结点,直到得到目标结点为止的一个隐式的图。标结点为止的一个隐式的图。一、图及其术语图及其术语第3页,共137页,编辑于2022年,星期一2.2.显式图的常用术语显式图的常用术语 图中的这些点图中的这些点(v(v1 1,v,v2 2,v,vn n)被称为被称为顶点顶点,连接顶点的曲线或直,连接顶点的曲线或直线称为线称为边边。通常将这种由若干个顶点以及连接某些顶点的边所组成的图形称通常将这种由若干个顶点以及连接某些顶点的边所组成的图形称为图,顶
3、点通常被称作是图中的数据元素为图,顶点通常被称作是图中的数据元素.第4页,共137页,编辑于2022年,星期一带权图:带权图:图的边上附加一个代表性数据图的边上附加一个代表性数据(比如表示长度、流量或其比如表示长度、流量或其他他),则称其为带权图,则称其为带权图。环环:顶点本身也有边相连,这种边称为环。:顶点本身也有边相连,这种边称为环。有限图:顶点与边数均为有限的图。有限图:顶点与边数均为有限的图。简单图:没有环且每两个顶点间最多只有一条边相连的图。简单图:没有环且每两个顶点间最多只有一条边相连的图。邻接与关联:当(邻接与关联:当(v1,v2)E,或,或E,即,即v1,v2间有边相连时,则称
4、间有边相连时,则称v1和和v2是相邻的,它们互为是相邻的,它们互为邻接点邻接点,同时称(,同时称(v1,v2)或)或是与顶点是与顶点v1、v2相关联的边。相关联的边。第5页,共137页,编辑于2022年,星期一度数度数:从该顶点引出的边的条数,简称度。:从该顶点引出的边的条数,简称度。入度:有向图中把以顶点为终点的边的条数。入度:有向图中把以顶点为终点的边的条数。出度:有向图中把以顶点为起点的边的条数。出度:有向图中把以顶点为起点的边的条数。终端顶点:有向图中出度为终端顶点:有向图中出度为0的顶点。的顶点。路径与路长:在图路径与路长:在图G=(V,E)中,如果存在由不同的边中,如果存在由不同的
5、边(vi0,vi1),(vi1,vi2),(vin-1,vin)或是或是,)组成的序列,则称顶点组成的序列,则称顶点vi0,vin是是连通连通的,顶点序列(的,顶点序列(vi0,vi1,vi2,vin)是从顶点)是从顶点vi0到顶点到顶点vin的一条道路。路长是道路上边的数目,的一条道路。路长是道路上边的数目,vi0到到vin的这的这条道路上的路长为条道路上的路长为n。连通图:对于图中任意两个顶点连通图:对于图中任意两个顶点vi、vjV,vi、vj之间有道之间有道路相连。路相连。网络:带权的连通图。网络:带权的连通图。第6页,共137页,编辑于2022年,星期一3 3隐式图术语隐式图术语 1)
6、子集树 当要求解的问题需要是在当要求解的问题需要是在n n 个元素的子集中进行搜索,其搜索空个元素的子集中进行搜索,其搜索空间树被称作子集树。这间树被称作子集树。这n n个元素都有在子集中或被选取记为个元素都有在子集中或被选取记为1 1,不在,不在子集中或被舍去记为子集中或被舍去记为0 0,这样搜索空间为:,这样搜索空间为:(0 0,0 0,0 0,0 0),(),(0 0,0 0,0 0,1 1),),(0 0,0 0,1 1,0 0),(),(0 0,0 0,1 1,1 1),),(1 1,1 1,1 1,1 1)。)。共共2 2n n 个状态。若表示为树形结构就是一棵有个状态。若表示为树
7、形结构就是一棵有2 2n n个叶结点的二叉树,对个叶结点的二叉树,对树中所有分支进行遍历的算法都必须耗时树中所有分支进行遍历的算法都必须耗时O(2n)。)。第7页,共137页,编辑于2022年,星期一n=3的子集树的子集树第8页,共137页,编辑于2022年,星期一2)排列树 当当要要求求解解的的问问题题需需要要在在n n 元元素素的的排排列列中中搜搜索索问问题题的的解解时时,解解空空间间树树被被称称作排列树。作排列树。搜索空间为:搜索空间为:(1 1,2 2,3 3,n-1n-1,n n),(2 2,1 1,3 3,n-1n-1,n n),(2 2,3 3,1 1,n-1n-1,n n),(
8、2 2,3 3,4 4,1 1,n-1n-1,n n),(n n,n-1n-1,3 3,2 2,1 1)第一个元素有第一个元素有n种选择,第二个元素有种选择,第二个元素有n-1种选择,第三个元素种选择,第三个元素有有n-2种选择,种选择,第,第n个元素有个元素有1种选择,共计种选择,共计n!个状态。若表示个状态。若表示为树形就是一个为树形就是一个n度树,这样的树有度树,这样的树有n!个叶结点,所以每一个遍历树个叶结点,所以每一个遍历树中所有节点的算法都必须耗时中所有节点的算法都必须耗时O(n!)第9页,共137页,编辑于2022年,星期一图图5-3n=4的部分子集树的部分子集树第10页,共13
9、7页,编辑于2022年,星期一4 4图的存储图的存储 邻接矩阵是表示顶点之间相邻关系的矩阵,邻接矩阵是表示顶点之间相邻关系的矩阵,设设G=(V,E)G=(V,E)是具有是具有n n个顶点的图,则个顶点的图,则G G的邻接矩阵可定义为:的邻接矩阵可定义为:Ai,j=1,Ai,j=1,若(若(V Vi i,V,Vj j)或或V 是是E(G)E(G)中的边。中的边。Ai,j=0,Ai,j=0,若若(V(Vi i,V,Vj j)或或V 不是不是E(G)E(G)中的边。中的边。若若G G是网络,则邻接矩阵可定义为:是网络,则邻接矩阵可定义为:Ai,j=W Ai,j=Wijij 若(若(V Vi i,V,
10、Vj j)或或V 属于属于E(G);E(G);Ai,j=0或或若(若(Vi i,Vj j)或)或不属于不属于E(G);其其中中,Wij表表示示边边上上的的权权值值,表表示示一一个个计计算算机机允允许许的的,大大于于所所有有边边上上权值的数;权值的数;1)邻接矩阵法第11页,共137页,编辑于2022年,星期一第12页,共137页,编辑于2022年,星期一2)邻接表 对于图对于图G G中的每个结点中的每个结点V Vi i,把所有邻接于把所有邻接于V Vi i的顶点的顶点V Vj j链成一个单链链成一个单链表,这个单链表就称为顶点表,这个单链表就称为顶点V Vi i的的邻接表邻接表。邻接表邻接表由
11、边表由边表和和顶点表顶点表两部分组成。两部分组成。无向图无向图:V Vi i的邻接表中每个表结点都对应于与的邻接表中每个表结点都对应于与V Vi i相关联的一条边,相关联的一条边,有向图有向图:V Vi i的邻接表中每个表结点对应于的邻接表中每个表结点对应于V Vi i为始点射出的一条边。为始点射出的一条边。第13页,共137页,编辑于2022年,星期一边表边表为一个单链表,每个表结点均有两个域:为一个单链表,每个表结点均有两个域:邻接点域邻接点域adjvexadjvex:存放与:存放与v vi i相邻接的顶点相邻接的顶点v vj j的序号的序号j j。链域链域nextnext:将邻接表的所有
12、表结点链在一起。:将邻接表的所有表结点链在一起。顶点表顶点表为一数组,每个元素均有两个域:为一数组,每个元素均有两个域:顶点域顶点域vertexvertex:存放顶点:存放顶点v vi i的信息的信息指针域指针域firstedgefirstedge:v vi i的边表的头指针。的边表的头指针。第14页,共137页,编辑于2022年,星期一 二、图搜索及其术语二、图搜索及其术语1 1穷举搜索与启发式搜索穷举搜索与启发式搜索 穷举搜索是对图的最基本的搜索算法,是蛮力策略的一种表穷举搜索是对图的最基本的搜索算法,是蛮力策略的一种表现形式。即不考虑给定问题的特有性质,按事先定好的顺序,依现形式。即不考
13、虑给定问题的特有性质,按事先定好的顺序,依次运用规则,盲目搜索的方法。次运用规则,盲目搜索的方法。启发式搜索是利用一些启发信息,提前判断出先搜索哪些状态可能尽快启发式搜索是利用一些启发信息,提前判断出先搜索哪些状态可能尽快找到问题的解或某些情况不可能取到最优解,从而可以提前舍弃对这些状态找到问题的解或某些情况不可能取到最优解,从而可以提前舍弃对这些状态的尝试。即考虑给定问题的特有性质,选用合适的细则,提高搜索的效率。的尝试。即考虑给定问题的特有性质,选用合适的细则,提高搜索的效率。第15页,共137页,编辑于2022年,星期一2 2相关概念和术语相关概念和术语 问题状态问题状态:树中的每一个结
14、点确定所求解问题的一个问题状态。树中的每一个结点确定所求解问题的一个问题状态。状态空间状态空间:由根结点到其它结点的所有路径(分支),就确定了这由根结点到其它结点的所有路径(分支),就确定了这个问题的状态空间。个问题的状态空间。解状态解状态:是这样一些问题状态是这样一些问题状态S,对于这些问题状态,由根到,对于这些问题状态,由根到S的的那条路径确定了这解空间中的一个元组。那条路径确定了这解空间中的一个元组。答案状态答案状态:是这样的一些解状态是这样的一些解状态S,对于这些解状态而言,由根到,对于这些解状态而言,由根到S的这条路径确定了这问题的一个解的这条路径确定了这问题的一个解状态空间树状态空
15、间树:解空间的树结构又称隐式图。解空间的树结构又称隐式图。第16页,共137页,编辑于2022年,星期一活结点:如果已生成一个结点而它的所有儿子结点活结点:如果已生成一个结点而它的所有儿子结点还没有全部生成,则这个结点叫做活结点。还没有全部生成,则这个结点叫做活结点。E-结点:当前正在生成其儿子结点的活结点叫结点:当前正在生成其儿子结点的活结点叫E-结点结点(正扩展的结点)。(正扩展的结点)。死结点死结点:不再进一步扩展或者其儿子结点已全部生成的:不再进一步扩展或者其儿子结点已全部生成的生成结点就是死结点生成结点就是死结点。第17页,共137页,编辑于2022年,星期一5.2广度优先搜索广度优
16、先搜索 从图中任选一顶点V为起点,首先访问V的所有邻接点W1,W2,Wt,然后再依次访问W1,W2,Wt邻接的所有未曾访问过的顶点。依此类推,直至图中所有和起点V有路径相通的顶点均已被访问为止。第18页,共137页,编辑于2022年,星期一一、算法框架一、算法框架 1 1算法的基本思路算法的基本思路算法设计的基本步骤为算法设计的基本步骤为:1)确定图的存储方式;)确定图的存储方式;2)图的遍历过程中的操作,其中包括为输出问)图的遍历过程中的操作,其中包括为输出问题解而进行的存储操作;题解而进行的存储操作;3 3)输出问题的结论。)输出问题的结论。第19页,共137页,编辑于2022年,星期一2
17、 2算法框架算法框架 1、通过通过E-E-结点扩展出的活结点结点扩展出的活结点2 2、活结点的扩展是按先来先处理的原则进行的、活结点的扩展是按先来先处理的原则进行的抽象地定义:抽象地定义:queuequeue为队列类型,为队列类型,InitQueue()InitQueue():队列初始化函数,:队列初始化函数,EnQueue(QEnQueue(Q,k)k):入队函数,:入队函数,QueueEmpty(Q)QueueEmpty(Q):判断队空函数,:判断队空函数,DeQueue(Q)DeQueue(Q):出队函数。:出队函数。visitedvisited:记录结点的搜索情况。:记录结点的搜索情况
18、。第20页,共137页,编辑于2022年,星期一1 1)邻接表表示图的广度优先搜索算法)邻接表表示图的广度优先搜索算法 intvisitedn;/n为结点个数bfs(intk,graphhead)inti;queueQ;edgenode*p;/定义队列InitQueue(Q);/队列初始化print(“visitvertex”,k);/访问源点vkvisitedk=1;EnQueue(Q,k);/vk已访问,将其入队while(!QueueEmpty(Q)/队非空则执行i=DeQueue(Q);/vi出队为E-结点p=headi.firstedge;/取vi的边表头指针while(pnull)
19、/扩展E-结点if(visitedp-adjvex=0)/若vj未访问过print(“visitvertex”,p-adjvex);/访问vjvisitedp-adjvex=1;EnQueue(Q,p-adjvex);/访问过的vj人队p=p-next;/找vi的下一邻接点第21页,共137页,编辑于2022年,星期一2 2)邻接矩阵表示的图的广度优先搜索算法)邻接矩阵表示的图的广度优先搜索算法bfsm(intk,graphg100,intn)inti,j;QueueQ;InitQueue(Q);print(“visitvertex”,k);/访问源点vkvisitedk=1;EnQueue(
20、Q,k);while(notQueueEmpty(Q)i=DeQueue(Q);/vi出队for(j=0;jn;j+)/扩展结点if(gij=1andvisitedj=0)print(“visitvertex”,j);visitedj=1;EnQueue(Q,j);/访问过的vj人队 第22页,共137页,编辑于2022年,星期一【例】如图表示的是从城市【例】如图表示的是从城市A A到城市到城市H H的交通图。从图中可的交通图。从图中可以看出,从城市以看出,从城市A A到城市到城市H H要经过若干个城市。现要找出一要经过若干个城市。现要找出一条经过城市最少一条路线。条经过城市最少一条路线。第2
21、3页,共137页,编辑于2022年,星期一算法过程:算法过程:1)将城市A(编号1)入队,队首qh置为0、队尾qe置为1。2)将队首所指的城市所有可直通的城市入队(如果这个城市在队中出现过就不入队),然后将队首加1,得到新的队首城市。重复以上步骤,直到城市H入队为止。当搜到城市H时,搜索结束。3)输出最少城市线路。第24页,共137页,编辑于2022年,星期一数据结构设计:数据结构设计:1)线性数组sq作为活结点队的存储空间。2)队列的每个结点有两个成员:sqi.city记录入队的城市,sqi.pre记录该城市的前趋城市在队列中的下标,这样通过sqi.pre就可以倒推出最短线路。3)设置数组v
22、isited记录已搜索过的城市。第25页,共137页,编辑于2022年,星期一算法:算法:intjz88=1,0,0,0,1,0,1,1,0,1,1,1,1,0,1,1,0,1,1,0,0,1,1,1,0,1,0,1,1,1,0,1,1,1,0,1,1,1,0,0,0,0,1,1,1,1,1,0,1,1,1,0,0,1,1,0,1,1,1,1,0,0,0,1;structintcity,pre;sq100;intqh,qe,i,visited100;main()inti,n=8;for(i=1;i=n,i=i+1)visitedi=0;search();第26页,共137页,编辑于2022年,
23、星期一search()()qh=0;qe=1;sq1.city=1;sq1.pre=0;visited1=1;qh=0;qe=1;sq1.city=1;sq1.pre=0;visited1=1;while(qhqe)/while(qhqe)/当队不空当队不空 qh=qh+1;/qh=qh+1;/结点出队结点出队 for(i=1;i=n,i+)/for(i=1;i=n,i+)/扩展结点扩展结点 if(jzsqqh.cityi=1 and visitedi=0 if(jzsqqh.cityi=1 and visitedi=0)qe=qe+1;/qe=qe+1;/结点入队结点入队 sqqe.city
24、=i;sqqe.city=i;sqqe.pre=qh;sqqe.pre=qh;visitedqe=1;visitedqe=1;if(sqqe.city=8)out();return;if(sqqe.city=8)out();return;print(“No avaliable way.”);print(“No avaliable way.”);第27页,共137页,编辑于2022年,星期一算法分析:时间复杂度是算法分析:时间复杂度是O(n);空间复杂性为();空间复杂性为(n2),包括图),包括图本身的存储空间和搜索时辅助空间本身的存储空间和搜索时辅助空间“队队”的存储空间。的存储空间。out
25、();/输出路径 print(sqqe.city);while(sqqe.pre0)qe=sqqe.pre;print(-,sqqe.city);第28页,共137页,编辑于2022年,星期一【例】走迷宫问题【例】走迷宫问题 迷宫是许多小方格构成的矩形,在每个小方格中有的是墙(图中的迷宫是许多小方格构成的矩形,在每个小方格中有的是墙(图中的“1 1”)有的是路(图中的有的是路(图中的“0 0”)。走迷宫就是从一个小方格沿上、下、左、右四个方向到邻近的方)。走迷宫就是从一个小方格沿上、下、左、右四个方向到邻近的方格,当然不能穿墙。设迷宫的入口是在左上角格,当然不能穿墙。设迷宫的入口是在左上角(1
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 第5章 图的搜索算法PPT讲稿 搜索 算法 PPT 讲稿
限制150内