题面翻译
AtCoder 王国流通着 N 种魔法石,编号为 1,2,…,N。高桥想要把魔法石排成一列做成装饰品。
有的魔法石能够相邻放在一起,有的魔法石却不行。有 M 组魔法石是可以相邻的,分别是 (魔法石 A1, 魔法石 B1), (魔法石 A2, 魔法石 B2), …, (魔法石 AM, 魔法石 BM)。除此之外的任何两个魔法石都不能相邻摆放。(可以相邻的魔法石摆放前后顺序不限。)
请判断是否存在这样一种排列方式,使得其中包含 C1,C2,…,CK 中的每一种魔法石。如果存在,求形成这样一个序列所需的最小宝石数量。如果不存在,输出 -1
。
题目描述
AtCoder 王国には 1, 2, …, N の番号がついた N 種類の魔法石が流通しています。
高橋くんは、魔法石を一列に並べて飾りを作ろうとしています。
魔法石には隣り合わせにできる組とできない組があります。 隣り合わせにできる組は (魔法石 A1, 魔法石 B1), (魔法石 A2, 魔法石 B2), …, (魔法石 AM, 魔法石 BM) の M 組で、それ以外の組は隣り合わせることができません。(これらの組において、石の順序は不問です。)
魔法石 C1, C2, …, CK をそれぞれ 1 個以上含む魔法石の列を作ることができるか判定し、作れる場合はそのような列を作るのに必要な魔法石の個数の最小値を求めてください。
输入格式
入力は以下の形式で標準入力から与えられる。
N M A1 B1 A2 B2 ⋮ AM BM K C1 C2 ⋯ CK
输出格式
魔法石 C1, C2, …, CK を含む魔法石の列を作るのに必要な魔法石の個数の最小値を出力せよ。
作ることができない場合、代わりに -1
を出力せよ。
样例 #1
样例输入 #1
4 3
1 4
2 4
3 4
3
1 2 3
样例输出 #1
5
样例 #2
样例输入 #2
4 3
1 4
2 4
1 2
3
1 2 3
样例输出 #2
-1
样例 #3
样例输入 #3
10 10
3 9
3 8
8 10
2 10
5 8
6 8
5 7
6 7
1 6
2 4
4
1 2 7 9
样例输出 #3
11
提示
制約
- 入力は全て整数
- 1 < =N < = 105
- 0 < =M < = 105
- 1 < = Ai < Bi < = N
- i = j ならば (Ai, Bi) = (Aj, Bj)
- 1 < = K < = 17
- 1 < = C1 < C2 < … < CK < = N
Sample Explanation 1
例えば、魔法石を [1, 4, 2, 4, 3] と並べると、魔法石 1, 2, 3 を含む長さ 5 の列を作ることができます。
Sample Explanation 3
例えば、魔法石を [1, 6, 7, 5, 8, 3, 9, 3, 8, 10, 2] と並べると、魔法石 1, 2, 7, 9 を含む長さ 11 の列を作ることができます。