zoukankan      html  css  js  c++  java
  • 从图的邻接表表示转换成邻接矩阵表示的算法

    加群获取学习资料QQ群:901381280

    分析:通过将邻接表的边映射到邻接矩阵上为1,没边的则为0

    #include<iostream>
    using namespace std;
    #define  MaxNum 20                 //图的最大顶点数
    #define MaxValue 65535			   //最大值
    // 定义边表结点
    struct ArcNode
    {
        int adjvex;                   // 邻接点域
        ArcNode* next;                 //下一个邻接点 
    };
    struct Graph
    {
    	struct  ArcNode* VertexNode[MaxNum];     //定义顶点表结点
    	int VertextNum;                //顶点数量
    	int EdgeNum;                   //边的数量 
    	int Edge[MaxNum][MaxNum];      //邻接矩阵 
    };
    void outAdjacency(Graph GM){        //输出邻接表 
    	
    	for(int i=1;i<=GM.VertextNum;i++){//定义顶点表结点
    	   
    	    ArcNode* B = new ArcNode;
    	    B= GM.VertexNode[i];
    	    cout << B->adjvex;
    		B = B->next; 
    	    while(B!=nullptr){
    	    	cout << "->"<<B->adjvex;
    	    	B = B->next;	    	
    		}
    		cout << "->Null"<<endl;
    	}
    }
    void adjacency_matrix(Graph GM){        //输出邻接矩阵 
    
    	for(int i=1;i<=GM.VertextNum;i++){//定义顶点表结点
    	    ArcNode* B = new ArcNode;
    	    B= GM.VertexNode[i];
    		B = B->next; 
    	    while(B!=nullptr){
    	    	GM.Edge[i][B->adjvex]=1;
    	    	B = B->next;	    	
    		}
    	}
    	for(int i=1;i<=GM.VertextNum;i++){    //打印邻接矩阵 
    		for(int j=1;j<=GM.VertextNum;j++){
    			  cout << GM.Edge[i][j] << " ";
    		}
    		cout << endl;
    	}
    }
    int main(){	
    	Graph GM;                     //初始化图
    	cin>>GM.VertextNum;           //输入顶点数量
    	cin>>GM.EdgeNum;              //入边的数量
    	for(int i=1;i<=GM.VertextNum;i++){//定义顶点表结点
    	    ArcNode* A = new ArcNode;
    		A->adjvex=i;
    		A->next=nullptr;
    		GM.VertexNode[i]=A;
    	}
    	for(int i=1;i<=GM.EdgeNum;i++){
    		int j,k;
    		cin >>j >>k ;
    		ArcNode* A = new ArcNode;
    		A->adjvex=k;
    		A->next=GM.VertexNode[j]->next;
    		GM.VertexNode[j]->next = A;
    	}
    	for(int i=1;i<=GM.VertextNum;i++){    //初始化邻接矩阵 为0; 
    		for(int j=1;j<=GM.VertextNum;j++){
    			  GM.Edge[i][j]=0; 
    		}
    	}
    	cout << "输出邻接表"<<endl;	
    	outAdjacency(GM);              //输出邻接表
    	cout << "输出邻接矩阵"<<endl;
    	adjacency_matrix(GM);         //输出邻接矩阵
    	return 0;
    }

    输入:

    4 5
    1 4
    4 3
    1 2
    2 4
    1 3

    输出结果:

    欢迎关注公众号:Python爬虫数据分析挖掘,方便及时阅读最新文章

                                 回复【开源源码】免费获取更多开源项目源码;

                     

  • 相关阅读:
    使用 C# 2008 Express Edition 编写的猜数字游戏
    话说三层
    在asp.net 1.1 中使用Ajax
    vs2005 调试时出现“无法附加。绑定句柄无效”的解决办法
    解决“你可能没有权限使用网络资源”的问题
    html&js 在firefox与IE中呈现存在差异的解决方法总结
    sql 事务 全攻略
    mssql的TSQL教程(从建登陆到建库、表和约束)(1)
    数据库练习题
    用批处理附加数据库
  • 原文地址:https://www.cnblogs.com/chenlove/p/14231694.html
Copyright © 2011-2022 走看看