欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    《图算法基础知识》PPT课件.ppt

    • 资源ID:5631207       资源大小:302.99KB        全文页数:29页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    《图算法基础知识》PPT课件.ppt

    图算法(一),Graph Algorithms,图,图 G=(V,E)V=顶点的非空有限集E=边集=V V的子集,V中顶点对,边的有限集。|E|=O(|V|2)简单图(Sample Graph)任意两个顶点最多只有一条边,且每个点都没有连接到自身的边。完全图(Complete Grapth)若有n个顶点的无向图n(n-1)/2条边,则此图为完全图。,图的扩展,扩展:连通图(connected graph)从图中每一顶点都有到其它顶点的路径。无向图(undirected graph):边(u,v)=边(v,u)有向图(directed graph):(u,v)表示从顶点u 到顶点 v的一条有向边,记为 uv一个不含有环的有向图称为无环有向图(Directed acyclic graphs,DAG)。加权图(weighted graph)图中不是边就是顶点与权关联,例如:公路交通图,边以距离w为权。,图,通常用边数|E|和顶点数|V|描述运行时间。无向图中 0|E|V|(|V|-1)/2有向图中 0|E|V|(|V|-1)若|E|V|2,图是稠密的 dense若|E|V|,图是稀疏的 sparse对稠密图和稀疏图使用不同的数据结构,图的表示,假设 V=1,2,n邻接矩阵(adjacency matrix)将图表示成一个 n x n 矩阵 A:Ai,j=1 若边(i,j)E(或边的权wij)=0 若边(i,j)E,图:邻接矩阵,Example:,1,2,4,3,有向图 非对称矩阵,图:邻接矩阵,Example:,1,2,4,3,a,d,b,c,图:邻接矩阵,Example:,1,2,4,3,a,d,b,c,图:邻接矩阵,Example:,1,2,4,3,5,1,4,3,图:邻接矩阵,Example:,1,2,4,3,a,d,b,c,无向图 对称矩阵,图:邻接矩阵,邻接矩阵的实现 const maxlength=100 最大顶点数type graph=array1.maxlength,1.maxlength of integer;二维数组,输入和查看一遍邻接矩阵需要多少时间?答:O(|V|2)存储一个邻接矩阵需要多少存储空间?答:O(|V|2)稀疏图(|E|V|或|E|V|),邻接矩阵是稀疏矩阵,浪费空间,因此采用邻接表更有效。,图:邻接矩阵,图:邻接表,邻接表:对每个顶点 v V,将v的所有邻接点存放在一个列表中。Example:Adj1=2,3Adj2=3Adj3=Adj4=3,1,2,4,3,1,2,4,3,图:邻接表,1,2,3,nil,2,3,nil,3,nil,4,3,nil,邻接表的实现Type pointer=adjnode adjnode=record adjvex:integer;该点在图中的位置 next:pointer;指向下一个顶点的指针 infor:;与边有关的信息,如权值w Adjlist=array1.maxlength of pointer;,图:邻接表,无环有向图的拓扑排序 Directed acyclic graphs(DAG)topological sort,DAG:不含回路的有向图称为无环有向图。检查有向图中是否存在回路的方法之一,是对有向图进行拓扑排序。,如果有向图G有一个拓扑排序,则G是一个有向无环图.反之,任一有向无环图必可进行拓扑排序。,何谓“拓扑排序”?,按照有向图给出的次序关系,将图中顶点排成一个线性序列,对于有向图中没有限定次序关系的顶点,则可以人为加上任意的次序关系。,由此所得顶点的线性序列称之为拓扑有序序列,例如:对于下列有向图,可求得拓扑有序序列:A B C D 或 A C B D,反之,对于下列有向图,不能求得它的拓扑有序序列。,因为图中存在一个回路 B,C,D,如何进行拓扑排序?,一、从有向图中选取一个没有前驱 的顶点,并输出之;,重复上述两步,直至图空,或者图不空但找不到无前驱的顶点为止。,二、从有向图中删去此顶点以及所 有以它为尾的弧;,a,b,h,c,d,g,f,e,在算法中需要用定量的描述替代定性的概念,没有前驱的顶点 入度为零的顶点,删除顶点及以它为尾的弧 弧头顶点的入度减1,拓扑排序算法,Function topsort:boolean;P140 var i,count:integer;wadj:Arr3;/用来表示图的邻接表表头数组 indeg:Arr1;/一维数组,存储每个顶点的入度 p:wpointer;/链表,邻接表 q:queue;/队列q保存入度为零且未被排序的顶点 begin/算法依次对q的出队元素进行编号 topsort:=true;count:=0;makenull(q);/清空队列q fillchar(indeg,sizeof(indeg),0);/数组indeg存储每个顶点入度,/通过遍历邻接表,计算所有顶点的入度For i:=1 to n do begin p:=wadji;/顶点i的邻接表的第一个邻接点 while pnil do/依次为顶点i的所有邻接点入度加1 begin inc(indegp.v);p:=p.next;end;End;,/入度为0的顶点加入队列qFor i:=1 to n do if indegi=0 then enqueue(i,q);/入队/队列q的队首顶点出队,与该顶点邻接的顶点的出度减1While not empty(q)do begin i:=dequeue(q);inc(count);/计数器加1 ordi:=count;/ord数组存储顶点i的排序后的序号 p:=wadji;while pnil do/该循环将顶点i的所有邻接点入度减1 begin dec(indegp.v);if indegp.v=0 then enqueue(p.v,q);p:=p.next;end End,/入度为0的顶点数小于n时,存在环;否则图不存在环,且可进行拓扑排序,ord数组存储的就是排序后的序号If countn then begin writeln(graph is cyclic);topsort:=false;end;End;,拓扑排序应用,字母排序给定的一组字母,并在该组字母上定义偏序关系,确定该组字母能否按此偏序关系升序排序。,例如,有序序列A,B,C,D表示A B,B C and C D.在该问题中,给出一形如A B的关系集,并要求确定该序列是否有序。,如果有序,输出这个序列,并输出是通过前多少关系得出的(即使之后的关系引出矛盾也不必理会)。如果存在矛盾,则输出前多少项出现的矛盾的。,具体思路:每输入一组偏序关系进行一次拓扑排序。如果存在回路,输出矛盾。在不存在回路的基础上,判断每次入度为0的点是否唯一,只有保证每次只有一个点入度为0,才能保证最终的序列唯一。,Input4 6/n=4表示字母数,2n26,m=6表示形如AB的偏序关 系数 AB/第1个偏序关系ACBCCDBDAB/第6个偏序关系 Output 4个关系后确定的有序序列:ABCD.,Input3 2/n=3表示字母数2n26,m表示形如AB的 偏序关系数 AB/第1个偏序关系BA/第2个偏序关系 Output Inconsistency found after 2 relations.,

    注意事项

    本文(《图算法基础知识》PPT课件.ppt)为本站会员(小飞机)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开