A83480.Shortest Path

普及/提高-

通过率:0%

时间限制:1.00s

内存限制:128MB

题目描述

在 Ancient Berland 有 nn 座城市和 mm 条长度均为 11 的双向道路。城市从 11nn 编号。根据一个古老的迷信说法,如果一个旅行者连续访问了 ai,bi,cia_i,b_i,c_i 三座城市而不去拜访其他城市,来自东方的神秘力量将使他遭受巨大的灾害。一共有 kk 组这样的城市,每个三元组都是有序的,这意味着你可以按照 ai,ci,bia_i,c_i,b_i 这样的方式来访问一组城市而不遭受灾害。Vasya 想要从城市 11 走到城市 nn 并且不受到诅咒。请告诉他最短路的长度,并输出一条路线。

输入格式

1133 个整数 n,m,k(2n3000,1m2×104,0k105)n,m,k(2\le n\le 3000,1\le m\le2\times10^4,0\le k\le10^5),分别表示城市数、路径数以及三元组数量。

接下来 mm 行,每行 22 个整数 xi,yi(1xi,yin)x_i,y_i(1\le x_i,y_i\le n),表示存在一条连接 xix_iyiy_i 的路,保证无重边和自环。

接下来 kk 行,每行 33 个整数 ai,bi,ci(1ai,bi,cin)a_i,b_i,c_i(1\le a_i,b_i,c_i\le n),表示一个诅咒三元组。不存在两个相同的三元组,且三个城市两两不同。

输出格式

可能从 11 号城市出发无法到达 nn 号城市,这种情况下输出 -1

否则第 11 行输出最短路长度 dd,第 22 行输出 d+1d+1 个数,表示一条可行最短路径。路径必须从 11 开始,在 nn 结束。

输入输出样例

  • 输入#1

    4 4 1
    1 2
    2 3
    3 4
    1 3
    1 4 3
    

    输出#1

    2
    1 3 4
    
  • 输入#2

    3 1 0
    1 2
    

    输出#2

    -1
    
  • 输入#3

    4 4 2
    1 2
    2 3
    3 4
    1 3
    1 2 3
    1 3 4
    

    输出#3

    4
    1 3 2 3 4
    
首页