农场主约翰在编号为1到V (1 <= V <= 1,000)一共V片草地上跟他的邻居农场主汤姆有着一个激烈的争吵。两个农场主目前正在这些草地上放养他们的奶牛,每片草地要不是空的,要不就被一只属于农场主约翰或者农场主汤姆的奶牛佔领着。 农场主约翰的耐心已经消磨完了,它希望把汤姆所有的奶牛都打到四脚朝天以解决这场争端。他当然希望可以抢占先机,并且尽可能多地打翻尽农场主汤姆的奶牛。 一共E (1 <= E <= 5,000)条双向道路连接E对草地。没有两片草地由超过一条道路连接,每条道路恰好连接2片不同的草地。每条路径由它的两个端点P1_i和P2_i (1 <= P1_i <= V; 1 <= P2_i <= V)描述。 在他的进攻过程中,农场主约翰的每一只奶牛如果需要的话,可以走过一条单独的道路。然后,如果她愿意,可以对相邻(也就是由一条单独的道路相连的)一片草地发动进攻,也就是把上面的敌牛打翻。注意她可以先移动再攻击 -- 但是她不能先攻击然后再移动。 每片草地上每个时刻最多可以有一只奶牛。一只奶牛不能移动到一个已经有奶牛在上面的草地上,尤其是上面的奶牛已经被打翻的时候。当然,如果一个草地已经被空出来了,另外一只奶牛可以在之后走到这片草地,以取代它的位置。一只被打翻的奶牛不能再次被打翻。 农场主约翰想要了解下面两个问题: 农场主约翰在这场战役的第一波攻击中,可以打翻农场主汤姆的多少只奶牛。 如何指挥他的奶牛来移动和攻击,以在这第一波攻击中,打翻最多的农场主汤姆的奶牛。 求出可以打翻的敌牛的最大数目,并按照上面的规则,构建出一个移动和攻击的命令序列来指挥他的奶牛以打翻这个数目的敌牛。只要能打翻最多的敌牛,任何一个符合条件的序列都是可以接受的。 考虑这样一个例子。一共有5片草地,分布在一条线上面,如果有的话,每片草地(经由'--',见下图)连接它左边和右边相邻的草地(如果有的话)。换句话说,草地1和草地2之间有一条道路相连,草地2到草地3之间有一条道路相连,等等。农场主汤姆('T')有两只奶牛,分别站在草地1和草地4上面,农夫约翰('J')有2只奶牛,站在草地3和草地5上面('E'表示空的草地): 1 2 3 4 5 T -- E -- J -- T -- J 在这个情况下,农场主约翰可以把农场主汤姆的两只奶牛都打翻。第一步把草地3上的奶牛移动到草地2。此时,现在草地上的情况是TJETJ。于是农场主约翰就可以让他两只奶牛都向左进攻。注意,虽然一开始在草地3上面的牛可以不需移动而向右攻击,但是这样的话最右边的奶牛就无法展开攻击了。于是唯一的可行解肯定跟上面提供的解法有着相同地移动与攻击,儘管农场主约翰指挥他的奶牛的具体顺序可能稍微有不同。 如果你正确计算出可以打翻敌牛的最大数目但是没有给出一个命令序列(或者这个序列出错),你将得到这个测试点的50%的分数。有一个程序会来给你的输出记分。
5 4 TEJTJ 1 2 2 3 3 4 4 5
2
输出细节:
其他可行的输出为:
2 MOVE 3 2 ATTACK 5 4 ATTACK 2 1
或者
2 ATTACK 5 4 MOVE 3 2 ATTACK 2 1
其它的输出祇是改变一下命令的顺序。但是并不是所有的数据都是这样的。