当前位置: 移动技术网 > IT编程>开发语言>C/C++ > 洛谷 P1346 电车

洛谷 P1346 电车

2018年09月03日  | 移动技术网IT编程  | 我要评论

永乐英雄儿女演员表,蘑菇该奖给谁,绿箭侠第二季下载

这道题的关键在建图

把每一个车站看成一个点,将这个车站相连的第一个车站建立一条边权为0的边,对于它所相连的其他车站,建立边权为1的边;

这样我们可以得到一张图;

起点,终点都知道了,跑一边最短路即可

最短路可以用spfa,floyd,迪杰斯特拉;

因为n只有200,跑遍floyd就行;

但是还有一个小细节;

对于我们建的每一条边,都只是单向边,不要加上f【i】【j】=f【j】【i】;

附ac代码:

 1 #include<cstdio>
 2 #include<cstring>
 3 #include<algorithm>
 4 #include<iostream>
 5 #include<string>
 6 #include<queue>
 7 #include<cmath> 
 8 #include<ctime>
 9 const int maxn=100+5;
10 const int inf=0x3f3f3f;
11 int dis[maxn][maxn];
12 int main()
13 {
14     int n,a,b;
15     int c,d;
16     scanf("%d %d %d",&n,&a,&b);
17     for(int i=1;i<=maxn-2;i++)
18         for(int j=1;j<=maxn-2;j++)
19             dis[i][j]=inf;
20     for(int i=1;i<=n;i++)
21     {
22         scanf("%d",&c);
23         for(int j=1;j<=c;j++)
24         {
25             scanf("%d",&d);
26             j==1?dis[i][d]=0:dis[i][d]=1;
27         }
28     }
29 
30     for(int k=1;k<=n;k++)
31         for(int i=1;i<=n;i++)
32             for(int j=1;j<=n;j++)
33                 dis[i][j]=std::min(dis[i][j],dis[i][k]+dis[k][j]); 
34     dis[a][b]==inf?printf("-1"):printf("%d",dis[a][b]); 
35 
36     return 0;
37 
38 }

更多代码请进入:https://github.com/tomatoschool

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网