无向图的邻接矩阵

#include <iostream>

using namespace std;

const int MAXVEX=4;

const int INFINITY=5200;

struct graph    //建立图的邻接矩阵,分别是顶点,邻接矩阵,顶点数,边数

{

    int vertex[MAXVEX];

    int arc[MAXVEX][MAXVEX];

    int numver,numedgs;

}MGraph;

void CreateGraph(graph *p)  //建立图

{

    cout<<"请输入图的顶点数与边数:"<<endl;

    cin>>p->numver>>p->numedgs;  /*输入顶点数,边数*/

    int i=0;

    for(int a=0;a<MAXVEX;a++)  /*初始化邻接矩阵,让矩阵先都为无穷大*/

    {

        for(int b=0;b<MAXVEX;b++)

            p->arc[a][b]=INFINITY;

    }

    while(i<p->numver)        /*输入顶点*/

    {

        cout<<"请输入顶点"<<endl;

        cin>>p->vertex[i];

        i++;

    }

    i=1;

    while(i<=p->numedgs)  /*将图的边放入邻接矩阵*/

    {

        cout<<"请输入该边所依附的邻接点:"<<endl;

        int a,b,w;

        cin>>a>>b;

        cout<<"请输入该边的权重"<<endl;

        cin>>w;

        p->arc[a-1][b-1]=w;

        p->arc[b-1][a-1]=p->arc[a-1][b-1]; /*因为是无向图,所以邻接矩阵是对称矩阵*/

        i++;

    }

}

int main()

{

    graph *p=new graph;

    CreateGraph(p);

    for(int i=0;i<p->numver;i++)      /*循环,输出邻接矩阵*/

    {

        for(int j=0;j<p->numver;j++)

        {

            if(j+1==p->numver)

                cout<<p->arc[i][j]<<endl;

            else

                cout<<p->arc[i][j]<<'\t';

        }

    }

    return 0;

}

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 无向图,是指在图中的每条边都是无向的,无向图G=<V,E>,其中V是非空集合,称为顶点集,E是V中元素构成的无序二...
    taylar_where阅读 13,236评论 0 6
  • 图的存储与遍历 一.实验目的 掌握图的存储结构以及图的深度优先搜索遍历、最小生成树算法。 二.实验要求与内容 自构...
    落幕12阅读 4,039评论 0 0
  • 1.把二元查找树转变成排序的双向链表 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。 要求不...
    曲终人散Li阅读 8,645评论 0 19
  • //正确 //现为无向图 //但是一下改成有向图好像有点不对,要琢磨下 #include #include //...
    天线斑斑阅读 4,781评论 0 0
  • #include #include<conio.h> //控制台数据输入输出的函数 #include<fstrea...
    黑键_阅读 4,952评论 0 1

友情链接更多精彩内容