AT_abc223_d [ABC223D] Restricted Permutation

题目描述

请在所有由 $ (1, 2, \dots, N) $ 重新排列得到的数列 $ P $ 中,找到满足以下条件的字典序最小的一个: - 对于 $ i = 1, \dots, M $,在 $ P $ 中 $ A_i $ 必须出现在 $ B_i $ 之前。 如果不存在这样的 $ P $,请输出 `-1`。

输入格式

输入以如下格式从标准输入读入。 > $ N $ $ M $ > $ A_1 $ $ B_1 $ > $\vdots$ > $ A_M $ $ B_M $

输出格式

请输出答案。

说明/提示

### 限制条件 - $2 \leq N \leq 2 \times 10^5$ - $1 \leq M \leq 2 \times 10^5$ - $1 \leq A_i, B_i \leq N$ - $A_i \neq B_i$ - 所有输入均为整数。 ### 样例解释 1 满足条件的 $ P $ 有 $ (2, 1, 3, 4), (2, 3, 1, 4), (2, 3, 4, 1), (3, 2, 1, 4), (3, 2, 4, 1) $ 共 $ 5 $ 个。其中字典序最小的是 $ (2, 1, 3, 4) $。 ### 样例解释 2 不存在满足条件的 $ P $。 由 ChatGPT 4.1 翻译