题意:火车从一点开到另一点,轨道上有很多岔路口,每个路口都有好几个方向(火车能够选任意一个方向开),但是 默认的是 第一个指向的方向,所以如果要选择别的方向的话得 进行一次切换操作 ,给定一个起点一个终点 ,问最少进行几次 切换操作 能够 使 火车 完成这个历程 , 如果开不到,输出“-1”。
貌似很简单啊,直接把与第一个相连的距离置为0,后面相连的置为1
然后用最短路的方法直接搞.......最短距离就是开关的次数。
不要忘记还有输出-1;(果断忘了一次)
///////////////////////////////////////////////////////////////////////
#include<stdio.h>
#include<vector>
#include<stack>
#include<algorithm>
#include<string.h>
#include<math.h>
using namespace std;
const int maxn = 10005;
const int maxm = 105;
const int oo = 0xfffffff;
struct node
{
int u, v, len, next;
}e[maxn];
int dis[maxn], head[maxn];
bool use[maxn];
void Add(int u, int v, int len, int k)
{
e[k].u = u;
e[k].v = v;
e[k].len = len;
e[k].next = head[u];
head[u] = k;
}
void spfa(int s)
{
stack<int> sta;
sta.push(s);
while(sta.size())
{
int i = sta.top();sta.pop();
use[i] = false;
for(int j=head[i]; j!=0; j=e[j].next)
{
int u = e[j].u, v=e[j].v, len = e[j].len;
if(dis[u]+len < dis[v])
{
dis[v] = dis[u] + len;
if(use[v] == false)
{
use[v] = true;
sta.push(v);
}
}
}
}
}
int main()
{
int N, A, B;
while(scanf("%d%d%d", &N, &A, &B) != EOF)
{
int i, j, k=1;
memset(head, 0, sizeof(head));
for(i=1; i<=N; i++)
{
int M, v;
dis[i] = oo;
scanf("%d%d", &M, &v);
Add(i, v, 0, k++);
for(j=1; j<M; j++)
{
scanf("%d", &v);
Add(i, v, 1, k++);
}
}
dis[A] = 0;
spfa(A);
if(dis[B] == oo)
printf("-1 ");
else
printf("%d ", dis[B]);
}
return 0;
}
#include<vector>
#include<stack>
#include<algorithm>
#include<string.h>
#include<math.h>
using namespace std;
const int maxn = 10005;
const int maxm = 105;
const int oo = 0xfffffff;
struct node
{
int u, v, len, next;
}e[maxn];
int dis[maxn], head[maxn];
bool use[maxn];
void Add(int u, int v, int len, int k)
{
e[k].u = u;
e[k].v = v;
e[k].len = len;
e[k].next = head[u];
head[u] = k;
}
void spfa(int s)
{
stack<int> sta;
sta.push(s);
while(sta.size())
{
int i = sta.top();sta.pop();
use[i] = false;
for(int j=head[i]; j!=0; j=e[j].next)
{
int u = e[j].u, v=e[j].v, len = e[j].len;
if(dis[u]+len < dis[v])
{
dis[v] = dis[u] + len;
if(use[v] == false)
{
use[v] = true;
sta.push(v);
}
}
}
}
}
int main()
{
int N, A, B;
while(scanf("%d%d%d", &N, &A, &B) != EOF)
{
int i, j, k=1;
memset(head, 0, sizeof(head));
for(i=1; i<=N; i++)
{
int M, v;
dis[i] = oo;
scanf("%d%d", &M, &v);
Add(i, v, 0, k++);
for(j=1; j<M; j++)
{
scanf("%d", &v);
Add(i, v, 1, k++);
}
}
dis[A] = 0;
spfa(A);
if(dis[B] == oo)
printf("-1 ");
else
printf("%d ", dis[B]);
}
return 0;
}