城市地图——图的深度优先遍历(邻接矩阵)

城市地图——图的深度优先遍历(邻接矩阵)

现在某地有h个城市,这些城市之间有k条道路,并且这些道路都是单行道

第一行输入h,n,m,k 

h表示城市个数,n表示出发城市,k表示目的城市,k表示单向道路个数

接下来k行,每行三个数据,第一个数据表示此条单行道的起始城市,第二个数据表示终点城市,第三个数据表示此条单行道的长度

最后输出一行表示从n城市至m城市的最短路程

样例输出:

5 1 5 8

1 2 2

1 5 10

2 3 3

2 5 7

3 1 4

3 4 4

4 5 5

5 3 3

样例输出:

9

代码如下:

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int n,m,h,min1=99999999;
int a[101][101]={0};
int book[105]={0};
void dfs(int cur,int dis)
{
    if(cur==m){
        if(dis<min1)min1=dis;
        return ;
    }
    if(dis>min1)return ;
    for(int i=1;i<=h;i++){
        if(a[cur][i]!=100000000&&a[cur][i]!=0&&book[i]==0)
        {
            book[i]=1;
            dfs(i,dis+a[cur][i]);
            book[i]=0;
        }
    }
    return ;
}
int main()
{
    int n1,n2,s,k;
    scanf("%d%d%d%d",&h,&n,&m,&k);//h代表一共有h个城市,n代表出发的城市,m代表目的城市,k代表有k条单向公路
    for(int i=1;i<=h;i++){
        for(int j=1;j<=h;j++){
            if(j==i)a[j][i]=0;
            else a[i][j]=min1+1;
        }
    }
    for(int i=1;i<=k;i++){
        scanf("%d%d%d",&n1,&n2,&s);
        a[n1][n2]=s;//因为是有向图所以只需赋值这一个即可,若为无向图则需赋值两个;
    }
    dfs(n,0);
    cout<<min1<<endl;
    return 0;
}

    原文作者:数据结构之图
    原文地址: https://blog.csdn.net/qq_40788630/article/details/80119219
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞