标题:图建立问题
只看楼主
咔叽
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2011-6-12
结帖率:0
已结贴  问题点数:20 回复次数:2 
图建立问题
建立图的存储结构(图的类型可以是有向图、无向图、有向网、无向网,学生可以任选两种类型),能够输入图的顶点和边的信息,并存储到相应存储结构中,而后输出图的邻接矩阵。
搜索更多相关主题的帖子: 学生 
2011-06-12 23:48
咔叽
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2011-6-12
得分:0 
2011-06-17 23:27
星翼凌空
Rank: 2
等 级:论坛游民
帖 子:3
专家分:20
注 册:2011-6-14
得分:20 
程序代码:
void CreateDG_AM(MGraph * G)
{
    int i, j, k;                       /*循环变量*/
    VertexType v1,v2;                      /*临时变量*/
    cout<<"请输入图的顶点数,边数(空格隔开,下面也是):";
    cin>>G->vexNum>>G->arcNum;
    cout<<"输入这"<<(G->vexNum)<<"顶点的值:";
    /*创建一个一维数组存放各顶点*/
    for(i = 0; i < G->vexNum; i++)     
    {
        cin>>G->vexs[i];
    }
    /*初始化邻接矩阵*/
    for(i = 0; i < G->vexNum; i++)    
        for(j = 0; j < G->vexNum; j++)
        {
            G->arcs[i][j].adj = INFINITY;
            G->arcs[i][j].info = NULL;
        }
    /*创建邻接矩阵*/
    cout<<"请输入弧尾和弧头:"<<endl;
    for(k = 0; k < G->arcNum; k++)
    {
        cin>>v1;
        cin>>v2;
        /*确定顶点在一维数组中的索引*/
        i = LocateVertex1(*G,v1);    
        j = LocateVertex1(*G,v2);
        G->arcs[i][j].adj = 1;
        /*与弧相关的信息*/
        if(G->arcs[i][j].info != NULL)
        {
            //......
        }
    }
    /*图的类型*/
    G->kind = UDG;
}

void DisplayDG_AM(MGraph G)
{
    int i,j;
    cout<<"有向图G具有:"<<G.vexNum<<"个顶点"<<G.arcNum<<"条弧"<<endl;
    cout<<"顶点依次是:";
    for(i = 0; i < G.vexNum; i++)
    {
        cout<<G.vexs[i]<<" ";
    }
    cout<<endl<<"序号i=";
    for(i = 0; i < G.vexNum; i++)
    {
        cout<<setw(8)<<i;
    }
    cout<<endl;
    for(i = 0; i < G.vexNum; i++)
    {
        cout<<setw(8)<<i;
        for(j = 0; j < G.vexNum; j++)
        {
            cout<<setw(8)<<G.arcs[i][j].adj;
        }
        cout<<endl;
    }
}
2011-06-18 11:58



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-342631-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 1.212334 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved