N - Tram - poj1847(简单最短路)

题意:火车从一点开到另一点,轨道上有很多岔路口,每个路口都有好几个方向(火车能够选任意一个方向开),但是 默认的是 第一个指向的方向,所以如果要选择别的方向的话得 进行一次切换操作 ,给定一个起点一个终点 ,问最少进行几次 切换操作 能够 使 火车 完成这个历程 , 如果开不到,输出“-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,  0sizeof(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\n ");
         else
            printf( " %d\n ", dis[B]);
    }

     return  0;
}

你可能感兴趣的:(poj)