AT_abc190_e [ABC190E] Magical Ornament
题目描述
在 AtCoder 王国中,流通着编号为 $1, 2, \dots, N$ 的 $N$ 种魔法石。
高桥君打算将魔法石排成一列来制作装饰品。
魔法石之间有些可以相邻,有些则不行。可以相邻的魔法石对有 $M$ 组,分别为 $(A_1, B_1), (A_2, B_2), \dots, (A_M, B_M)$,除此之外的组合都不能相邻(这些组合中,石头的顺序无关紧要)。
请判断是否可以制作一个包含魔法石 $C_1, C_2, \dots, C_K$,且每种至少出现一次的魔法石序列。如果可以,请求出制作这样一个序列所需的最少魔法石数量。
输入格式
输入按以下格式从标准输入读入。
> $N$ $M$
> $A_1$ $B_1$
> $A_2$ $B_2$
> $\vdots$
> $A_M$ $B_M$
> $K$
> $C_1$ $C_2$ $\cdots$ $C_K$
输出格式
输出制作包含魔法石 $C_1, C_2, \dots, C_K$ 的魔法石序列所需的最小魔法石数量。
如果无法制作,输出 $-1$。
说明/提示
## 限制条件
- 所有输入均为整数。
- $1 \leq N \leq 10^5$
- $0 \leq M \leq 10^5$
- $1 \leq A_i < B_i \leq N$
- 若 $i \neq j$,则 $(A_i, B_i) \neq (A_j, B_j)$
- $1 \leq K \leq 17$
- $1 \leq C_1 < C_2 < \dots < C_K \leq N$
## 样例解释 1
例如,将魔法石排列为 $[1, 4, 2, 4, 3]$,可以制作一个包含魔法石 $1, 2, 3$ 的长度为 $5$ 的序列。
## 样例解释 3
例如,将魔法石排列为 $[1, 6, 7, 5, 8, 3, 9, 3, 8, 10, 2]$,可以制作一个包含魔法石 $1, 2, 7, 9$ 的长度为 $11$ 的序列。
由 ChatGPT 4.1 翻译