图的邻接矩阵实现问题幻灯片.ppt
《图的邻接矩阵实现问题幻灯片.ppt》由会员分享,可在线阅读,更多相关《图的邻接矩阵实现问题幻灯片.ppt(16页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、图的邻接矩阵实现问题第1页,共16页,编辑于2022年,星期五设计目的 通过对图遍历的程序编写,掌握邻接矩阵的定义,并对其进行深度优先搜索和广度优先搜索。1.测试图的手工表示结果。测试图的手工表示结果。第2页,共16页,编辑于2022年,星期五2.测试图的数据表示,邻接矩阵特点。测试图的数据表示,邻接矩阵特点。邻接矩阵,对与图G,可用一个方阵A=(aij)n*n表示,其中aij=1,表示vi和vj之间有边,为0表示无边。邻接矩阵可表示自环和重边,在有向图中,aij表示定点vi和vj之间边的条数。无向图的邻接矩阵一定是对称的,而有向图的邻接矩阵不一定对称。因此,用邻接矩阵来表示一个具有n个顶点的
2、有向图时需要n2个单元来存储邻接矩阵;对有n个顶点的无向图则只存入上(下)三角阵中剔除了左上右下对角线上的0元素后剩余的元素,故只需1+2+.+(n-1)=n(n-1)/2个单元。无向图邻接矩阵的第i行(或第i列)非零元素的个数正好是第i个顶点的度。有向图邻接矩阵中第i行非零元素的个数为第i个顶点的出度,第i列非零元素的个数为第i个顶点的入度,第i个顶点的度为第i行与第i列非零元素个数之和。用邻接矩阵表示图,很容易确定图中任意两个顶点是否有边相连。第3页,共16页,编辑于2022年,星期五3.图的类设计方法。图的类设计方法。对于深度优先搜索我们采用递归操作;广度优先搜索采用非递归操作,对于深度
3、优先搜索我们采用递归操作;广度优先搜索采用非递归操作,在此过程中引用栈消除递归。在此过程中引用栈消除递归。类类DFS用于深度优先搜索,栈用于深度优先搜索,栈g1为其边赋值。为其边赋值。类类BFS用于广度优先搜索,栈用于广度优先搜索,栈g2为其边赋值。为其边赋值。图类图类Graphm用于定义图中顶点和边的相关信息。用于定义图中顶点和边的相关信息。第4页,共16页,编辑于2022年,星期五第5页,共16页,编辑于2022年,星期五源程序:public class BFS/*param args*/public static void main(String args)/TODO Auto-gene
4、rated method stubchar m=a,b,c,d,e,f,g,h;Graphm g1=new Graphm(8);/给图的边赋值g1.setedge(0,1,1);g1.setedge(1,3,1);g1.setedge(1,4,1);g1.setedge(3,7,1);g1.setedge(4,7,1);g1.setedge(0,2,1);g1.setedge(2,5,1);g1.setedge(2,6,1);g1.setedge(5,6,1);第6页,共16页,编辑于2022年,星期五/深度优先搜索方法/System.out.println(深度优先输出:);/DFS(g1,
5、0,m);/System.out.println();/Graphm g2=new Graphm(8);/给图的边赋值/g2.setedge(0,1,1);/g2.setedge(1,3,1);/g2.setedge(1,4,1);/g2.setedge(3,7,1);/g2.setedge(4,7,1);/g2.setedge(0,2,1);/g2.setedge(2,5,1);/g2.setedge(2,6,1);/g2.setedge(5,6,1);/System.out.println(广度度优先输出:);/BFS(g2,0,m,8);第7页,共16页,编辑于2022年,星期五for(
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 邻接矩阵 实现 问题 幻灯片
限制150内