图的邻接矩阵和邻接表相互转换

图的邻接矩阵和邻接表相互转换

ID:10130392

大小:42.00 KB

页数:5页

时间:2018-06-11

图的邻接矩阵和邻接表相互转换_第1页
图的邻接矩阵和邻接表相互转换_第2页
图的邻接矩阵和邻接表相互转换_第3页
图的邻接矩阵和邻接表相互转换_第4页
图的邻接矩阵和邻接表相互转换_第5页
资源描述:

《图的邻接矩阵和邻接表相互转换》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、图的邻接矩阵和邻接表相互转换图的邻接矩阵存储方法具有如下几个特征:1)无向图的邻接矩阵一定是一个对称矩阵。2)对于无向图的邻接矩阵的第i行非零元素的个数正好是第i个顶点的度。3)对于有向图,邻接矩阵的第i行非零元素的个数正好是第i个顶点的出度(或入度)。4)用邻接矩阵方法存储图,很容易确定图中任意两个顶点之间是否有边相连;但是,要确定图中有多少条边,则必须按行、按列对每个元素进行检测,所发费得时间代价大。邻接表是图的一种顺序存储与链式存储相结合的存储方法。若无向图中有n个顶点、e条边,则它的邻接表需

2、n个头结点和2e个表结点。显然,在边稀疏的情况下,用邻接表表示图比邻接矩阵存储空间。在无向图的邻接表中,顶点的度恰好是第i个链表中的结点数,而在有向图中,第i个链表中结点个数是顶点的出度。在建立邻接表或邻逆接表时,若输入的顶点信息即为顶点的编号,则建立临接表的时间复杂度是;否则,需要通过查找才能得到顶点在图中位置,则时间复杂度为。在邻接表上容易找到任意一顶点的第一个邻接点和下一个邻接点,但要判断任意两个顶点之间是否有边或弧,则需要搜索第i个或第j个链表,因此,不及邻接矩阵方便。邻接矩阵和邻接表相互转

3、换程序代码如下:#include#defineMAX20//图的邻接表存储表示typedefstructArcNode{intadjvex;//弧的邻接定点charinfo;//邻接点值structArcNode*nextarc;//指向下一条弧的指针}ArcNode;typedefstructVnode{//节点信息chardata;ArcNode*link;}Vnode,AdjList[MAX];typedefstruct{AdjListvertices;intvexnu

4、m;//节点数intarcnum;//边数}ALGraph;//图的邻接矩阵存储表示typedefstruct{intn;//顶点个数charvexs[MAX];//定点信息intarcs[MAX][MAX];//边信息矩阵}AdjMatrix;/***_____________________________________________________***///函数名:AdjListToMatrix(AdjListg1,AdjListMatrix&gm,intn)//参数:(传入)AdjLi

5、stg1图的邻接表,(传入)intn顶点个数,(传出)AdjMatrixgm图的邻接矩阵//功能:把图的邻接表表示转换成图的邻接矩阵表示voidAdjListToAdjMatrix(ALGraphgl,AdjMatrix&gm){inti,j,k;ArcNode*p;gm.n=gl.vexnum;for(k=0;k

6、]=0;for(i=0;iadjvex]=1;p=p->nextarc;}}}/***________________________________________________***///函数名:AdjMatrixToAdjListvoidAdjMatrixToAdjList(AdjMatrixgm,ALGraph&gl)

7、{inti,j,k,choice;ArcNode*p;k=0;gl.vexnum=gm.n;cout<<"请选择所建立的图形是无向图或是有向图:";cin>>choice;for(i=0;iadjvex=j;p

8、->info=gm.vexs[j];p->nextarc=gl.vertices[i].link;gl.vertices[i].link=p;}if(choice==1)k=k/2;gl.arcnum=k;}voidCreateAdjList(ALGraph&G){inti,s,d,choice;ArcNode*p;cout<<"请选择所建立的图形是有向图或是无向图:";cin>>choice;cout<<"请输入节点数和边数:"<>G.vexnu

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。