小垃圾的跟班


私信TA

用户名:1298743454

访问量:12196

签 名:

等  级
排  名 1806
经  验 2626
参赛次数 0
文章发表 23
年  龄 0
在职情况 学生
学  校 陕西科技大学
专  业

  自我简介:

#include<iostream>
#include <cstdio>
#include <cstdlib>
using namespace std;
//图的邻接矩阵存储结构
typedef char VertexType;//顶点类型应由用户定义
typedef int EdgeType;//边上的权值类型应由用户定义
#define ok 1
#define false 0
#define MAXVEX 100 //最大顶点数,应由用户定义
#define INFINITY 100000 //用65535代表无穷远,表示不相邻
typedef struct
{
 VertexType vexs[MAXVEX];//顶点表
 EdgeType arc[MAXVEX][MAXVEX];//邻接矩阵,可看作边表
 int numVertexes,numEdges;//图中当前的顶点数和边数
}MGraph;
int creat_graph(MGraph *g){
  int i,j,k,w;
  //输入顶点数和边数
  cin>>g->numVertexes>>g->numEdges;
  //初始化邻接矩阵
  for(i=0;i<g->numVertexes;i++){
    for( j=0;j<g->numVertexes;j++){
      g->arc[i][j]=INFINITY;
    }
  }
  //用边数在邻接表中进行赋值操作
  for( k=0;k<g->numEdges;k++){
    cin>>i>>j>>w;
    g->arc[i][j]=w;
    //有向图时不需要这个,无向图时需要加上
    g->arc[j][i]=g->arc[i][j];
  }
  return ok;
}
//打印邻接表
int printf_linjiebiao( MGraph *g){
  for(int i=0;i<g->numVertexes;i++){
    for(int j=0;j<g->numVertexes;j++){
      cout<<g->arc[i][j]<<" ";
    }
    cout<<endl;
  }
  return ok;
}
int main(int argc, char const *argv[]) {
  MGraph g;
  creat_graph(&g);
  printf_linjiebiao(&g);
  return 0;
}


 

0.0分

0 人评分

  评论区

  • «
  • »