#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define MAX 20
#define MAX_VERTEX_NUM 20
#define INF -1
#define error -1
//邻接矩阵
typedef struct ArcCell
{
int adj;
}ArcCell,AdjMatrix[MAX_VERTEX_NUM][MAX_VERTEX_NUM];
typedef struct
{
int vexnum,arcnum; //点数和边数
AdjMatrix arcs; //邻接矩阵
char vexs[MAX][MAX];
}MGraph;
//函数原型:
void CreateUDN(MGraph &G);
void show(MGraph G);
int LocatVex(MGraph G,char v[MAX]);
int main()
{
MGraph G;
CreateUDN(G);
show(G);
return 0;
}
void CreateUDN(MGraph &G)
{
int i,j,v;
char v1[MAX],v2[MAX];
printf("请输入顶点的个数: ");
scanf("%d",&G.vexnum);
printf("请输入边的总数: ");
scanf("%d",&G.arcnum);
for(i=0;i<G.vexnum;i++)
{
printf("请输入第%d个顶点的名称: ",i+1);
scanf(" %s",G.vexs[i]);
}
for(i=0;i<G.vexnum;i++) //初始化
{
for(j=0;j<G.vexnum;j++)
{
G.arcs[i][j].adj=INF;
}
}
for(v=0;v<G.arcnum;v++)
{
printf("请输入第一个顶点: ");
scanf("%s",&v1);
i=LocatVex(G,v1);
printf("请输入第二个顶点: ");
scanf("%s",&v2);
j=LocatVex(G,v2);
if(i!=error && j!=error)
{
printf("请输入两点之间的权值: ");
scanf("%d",&G.arcs[i][j].adj);
G.arcs[j][i]=G.arcs[i][j];
}
else exit(0);
}
}
int LocatVex(MGraph G,char v[MAX])
{
int i;
for(i=0;i<G.vexnum;i++)
{
if(strcmp(G.vexs[i],v)==0)
{
return i;
}
}
return error;
}
void show(MGraph G)
{
int i,j;
for(i=0;i<G.vexnum;i++)
{
for(j=0;j<G.vexnum;j++)
{
printf("%3d",G.arcs[i][j].adj);
}
printf("\n");
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/69348.html