#P2774. 「BalticOI 2018」多角恋

「BalticOI 2018」多角恋

题目描述

题目译自 BalticOI 2018 Day1「Love Polygon

给一张 NN 个点的有向图,每次可以花费 11 的代价修改图上的一条边的终点。求最少需要花费多少代价,才能使这张图形成若干个两两不相交的二元环,并且图上的所有点都在某一个环里。

输入格式

第一行包含一个整数 NN

接下来的 NN 行每行包含两个字符串 sstt,表示图中存在一条 (st)(s\rightarrow t) 的边。

字符串只包含小写英文字母,且长度不超过 1010

输出格式

输出一个整数,表示最少需要花费多少代价,才能使这张图形成若干个两两不相交的环,并且图上的所有点都在某一个环里。无解请输出 1-1

8
leonard emmy
ada emmy
isaac leonard
emmy pierre
pierre bernhard
bernhard emmy
sofia karl
karl sofia
3
4
a
c
b c
c d
d d
3
3
rocky scarlet
scarlet patrick
patrick rocky
-1

数据范围与提示

子任务 分值 数据范围 附加限制
11 2121 2N202\leqslant N\leqslant 20
22 2525 2N1000002\leqslant N\leqslant 100\, 000 每个点都有一条入边(可能有自环)
33 2929 不存在两个点或更多个点构成的环
44 2525

请注意在 LibreOJ 上共有 55 个子任务,其中第一个子任务为样例。