loj#P2853. 「CEOI2012」帆船比赛

「CEOI2012」帆船比赛

题目描述

译自 CEOI 2012 Day1 T3「Sailing Race

一年一度的帆船比赛在一个圆形的湖上举行。湖周围有 NN 个港口,逆时针方向从 11NN 编号。

比赛由几个赛段组成,每个赛段是从一个港口到另一个港口的线段,赛道最多只能到达一个港口一次。组织者想要创建一个包含尽可能多的赛段的赛道。他们必须记住,在一个特定港口的帆船可能只能以直航的方式前往某些特定的港口。幸运的是,对于每个港口 AA,他们都有从 AA 出发的直达目的地的列表,即帆船可以从 AA 出发直线到达的其他港口的列表。通常,赛道由不相交的阶段组成,以避免帆船的碰撞。

然而,今年有了一项新技术,如果这条赛道位于第一阶段,那么它可能会允许一条赛道穿过它。所以如果赛道从 SS 港开始,赛道上的下一个港口是 TT,那么最多有一个赛段可以从第一赛段 STS-T 中穿过。组织者可能会决定允许这样的十字路口出现,或者选择不交叉的经典设计。

你需要编写一个程序,计算给定类型的赛道,其中包含尽可能多的赛段。

输入格式

输入的第一行包含两个整数,第一个 NN 为港口数量,第二个 kk 为所需赛道类型。如果 kk00,则需要使用经典赛道(无交叉),而如果 kk11 则赛道中最多可以包含一个交叉,如上所述。

接下来的 NN 行包含从港口出发的直接目的地的列表。第 (i+1)(i + 1) 行包含港口 ii 的列表,有若干个由空格分隔的整数,以 00 结束。

输出格式

输出的第一行包含一个整数 MM,这是给定类型的赛道可以包含的最大赛段数。第二行包含一个这样的赛道的起始港的标识符编号。如果有多个解决方案,输出任意一个即可。

7 1
5 0
5 0
7 0
3 0
4 0
4 3 0
2 1 0

5
2

数据范围与提示

  • 对于 40%40\% 的数据,k=0k = 0
  • 对于 50%50\% 的数据,N100N \leq 100
  • 对于 100%100\% 的数据,1N5001 \leq N \leq 500