图论 邻接矩阵建图+dfs遍历

第一次i建图,用的邻接矩阵。

#include
#include
#include
#include
#include
#define inf 65535
using namespace std;
typedef struct mygraph
{
    int ver[1000];
    int arc[100][100];
    int num_ver,num_edge;
} Graph;
int vis[100];
void create(Graph *G)//邻接矩阵建图
{
    int i,j,k;
    scanf("%d%d",&G->num_ver,&G->num_edge);//输入节点数和边数
    for(i=0; inum_ver; i++)//输入边集
        scanf("%d",&G->ver[i]);
    for(i=0; inum_ver; i++)//权值初始化
    {
        for(j=0; jnum_edge; j++)
            G->arc[i][j]=inf;
    }
    int a,b,c;
    for(i=0; inum_edge; i++)//输入边集
    {
        scanf("%d%d%d",&a,&b,&c);
        G->arc[a][b]=c;
        G->arc[b][a]=c;
    }
}
void dfs(Graph *G,int i)//深搜
{
    int j;
    vis[i]=1;
    printf("%d ",G->ver[i]);
    for(j=0; jnum_ver; j++)
        if(G->arc[i][j]>0&&!vis[j])dfs(G,j);
}


int main()
{
    int i,j,k;
    Graph myG;
    create(&myG);
    memset(vis,0,sizeof(vis));
    
    //深搜遍历
    for(i=0; i
测试数据中5  6代表节点数为5,边数为,6,下面是结点名0 1 2 3 4  下面几行中分别为为 弧尾(边的起点),弧首(边的终点),和边的权值

你可能感兴趣的:(图论,邻接矩阵)