zoukankan      html  css  js  c++  java
  • N

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

        return 0;
    }
  • 相关阅读:
    favicon.ico在线制作,在线Favicon.ico制作转换工具
    素材之家,中国免费素材下载网站!下免费素材就到素材之家!
    visual assit 2010 2008均可用
    SQL server2008卸载出现重启怎么解决
    ping测试网络
    inndy_rop
    BJDCTF 2nd web
    [BJDCTF 2nd]one_gadget
    bjdctf_2020_babystack2
    堆溢出之unlink
  • 原文地址:https://www.cnblogs.com/liuxin13/p/4661137.html
Copyright © 2011-2022 走看看