猪国杀
题号:NC210160
时间限制:C/C++/Rust/Pascal 1秒,其他语言2秒
空间限制:C/C++/Rust/Pascal 256 M,其他语言512 M
64bit IO Format: %lld

题目描述

《猪国杀》是一种多猪牌类回合制游戏,一共有三种角色:主猪,忠猪,反猪。每局游戏主猪有且只有一只,忠猪和反猪可以有多只,每只猪扮演一种角色。

游戏目的:

主猪(MP):自己存活的情况下消灭所有的反猪。

忠猪(ZP):不惜一切保护主猪,胜利条件与主猪相同。

反猪(AP):杀死主猪。

游戏过程:

游戏开始时候,每个玩家手里都会有4张牌,且体力上限和初始体力都是4。

开始游戏时,从主猪开始,按照逆时针方向(数据中就是按照编号从1,2,3..n,1..的顺序)依次行动。

每个玩家自己的回合可以分为4个阶段:

◎摸牌阶段:从牌堆顶部摸两张牌,依次放到手牌的最右边;

◎出牌阶段:你可以使用0张到任意张牌,每次使用牌的时候都使用最靠左的能够使用的牌。当然,要满足如下规则:

1.如果没有猪哥连弩,每个出牌阶段只能使用一次“杀”来攻击;

2.任何牌被使用后被弃置(武器是装备上);

被弃置的牌以后都不能再用,即与游戏无关;

各种牌介绍:

每张手牌用一个字母表示,字母代表牌的种类。

◎基本牌:

『桃(P)』:在自己的回合内,如果自己的体力值不等于体力上限,那么使用一个桃可以为自己补充一点体力,否则不能使用桃;桃只能对自己使用;在自己的回合外,如果自己的血变为0或者更低,那么也可以使用;

『杀(K)』:在自己的回合内,对攻击范围内除自己以外的一名角色使用。如果没有被『闪』抵消,则造成1点伤害。无论有无武器,杀的攻击范围都是1;

『闪(D)』:当你受到杀的攻击时,可以弃置一张闪来抵消杀的效果;

◎锦囊牌:

『决斗(F)』:出牌阶段,对除自己以外任意一名角色使用,由目标角色先开始,自己和目标角色轮流弃置一张杀,首先没有杀可弃的一方受到1点伤害,另一方视为此伤害的来源;

『南猪入侵(N)』:出牌阶段,对除你以外所有角色使用,按逆时针顺序从使用者下家开始依次结算,除非弃置一张杀,否则受到1点伤害;

    『万箭齐发(W)』:和南猪入侵类似,不过要弃置的不是杀而是闪;

『无懈可击(J)』:在目标锦囊生效前抵消其效果。每次有一张锦囊即将生效时,从使用这张锦囊的猪开始,按照逆时针顺序,依次得到使用无懈可击的机会;

效果:用于决斗时,决斗无效并弃置;用于南猪入侵或万箭齐发时,当结算到某个角色时才能使用,当前角色不需弃置牌并且不会受到伤害(仅对一个角色产生效果);用于无懈可击时,成为目标的无懈可击被无效。

◎装备牌:

     『猪哥连弩(Z)』:武器,攻击范围1,出牌阶段你可以使用任意张杀;

同一时刻最多只能装一个武器;如果先前已经有了一把武器,那么之后再装武器的话,会弃置以前的武器来装现在的武器;

特殊事件及概念解释:

◎伤害来源:杀、南猪入侵、万箭齐发的伤害来源均是使用该牌的猪,决斗的伤害来源如上;

◎距离:两只猪的距离定义为沿着逆时针方向间隔的猪数+1。即初始时1和2的距离为1,但是2和1的距离就是n-1。注意一个角色的死亡会导致一些猪距离的改变;

◎玩家死亡:如果该玩家的体力降到0或者更低,并且自己手中没有足够的桃使得自己的体力值回到1,那么就死亡了,死亡后所有的牌(装备区,手牌区)被弃置;

◎奖励与惩罚:反猪死亡时,最后一个伤害来源处(即使是反猪)立即摸三张牌。忠猪死亡时,如果最后一个伤害来源是主猪,那么主猪所有装备牌、手牌被弃置;

◎注意,一旦达成胜利条件,游戏立刻结束,因此即使会摸3张牌或者还有牌可以用也不用执行了。

现在,我们已经知道每只猪的角色、手牌,还有牌堆初始情况,并且假设每个角色会按照如下的行为准则进行游戏,你需要做的就是告诉小猪iPig最后的结果。

几种行为:

◎献殷勤:使用无懈可击挡下南猪入侵、万箭齐发、决斗;使用无懈可击抵消表敌意;

◎表敌意:对某个角色使用杀、决斗;使用无懈可击抵消献殷勤;

◎跳忠:即通过行动表示自己是忠猪。跳忠行动就是对主猪或对某只已经跳忠的猪献殷勤,或者对某只已经跳反的猪表敌意;

◎跳反:即通过行动表示自己是反猪。跳反行动就是对主猪或对某只已经跳忠的猪表敌意,或者对某只已经跳反的猪献殷勤;

忠猪不会跳反,反猪也不会跳忠;不管是忠猪还是反猪,能够跳必然跳;

行动准则:

共性:每个角色如果手里有桃且生命值未满,那么必然吃掉;有南猪入侵、万箭齐发、必然使用;有装备必然装上;受到杀时,有闪必然弃置;响应南猪入侵或者万箭齐发时候,有杀/闪必然弃置;不会对未表明身份的猪献殷勤(包括自己);

特性:

◎主猪:主猪会认为没有跳身份,且用南猪入侵/万箭齐发对自己造成伤害的猪是“类反猪”(没伤害到不算,注意“类反猪”并没有表明身份),如果之后跳了,那么主猪会重新认识这只猪;对于每种表敌意的方式,对逆时针方向能够执行到的第一只“类反猪”或者已跳反猪表;如果没有,那么就不表敌意;决斗时会不遗余力弃置杀;如果能对已经跳忠的猪或自己献殷勤,那么一定献;如果能够对已经跳反的猪表敌意,那么一定表;

◎忠猪:对于每种表敌意的方式,对逆时针方向能够执行到的第一只已经跳反的猪表,如果没有,那么就不表敌意;决斗时,如果对方是主猪,那么不会弃置杀,否则,会不遗余力弃置杀;如果有机会对主猪或者已经跳忠的猪献殷勤,那么一定献;

◎反猪:对于每种表敌意的方式,如果有机会则对主猪表,否则,对逆时针方向能够执行到的第一只已经跳忠的猪表,如果没有,那么就不表敌意;决斗时会不遗余力弃置杀;如果有机会对已经跳反的猪献殷勤,那么一定献;

限于iPig只会用P++语言写A + B,他请你用Pigcal(Pascal)、P(C)或P++(C++)语言来帮他预测最后的结果。

输入描述:

输入文件第一行包含两个正整数n(2 <= n <= 5) 和m( m <= 2000),分别代表玩家数和牌堆中牌的数量。数据保证牌的数量够用。

接下来n行,每行5个字符串,依次表示对第i只猪的角色和初始4张手牌描述。编号为1的肯定是主猪。

再接下来一行,一共m个字符串,按照从牌堆顶部到牌堆底部的顺序描述每张牌。

所有的相邻的两个字符串都严格用1个空格隔开,行尾没有多余空格。

输出描述:

输出数据第一行包含一个字符串代表游戏结果。如果是主猪胜利,那么输出“MP”,否则输出“FP”。数据保证游戏总会结束。

接下来n行,第i行是对第i只猪的手牌描述(注意只需要输出手牌),按照手牌从左往右的顺序输出,相邻两张牌用一个空格隔开,行末尾没有多余空格。如果这只猪已阵亡,那么只要输出“DEAD”即可。注意如果要输出手牌而没有手牌的话,那么只需输出一个空行。

示例1

输入

复制
5 2000
MP D F W D
FP W N P N
ZP P F P K
FP D K P P
FP F D K K
D P F P K D P K D D F K F P P D K K N Z K D W D F D K K P K W N F N F W W N K F K W D N P P K P F F W P F N K F K D D K N N N F K N K N D D P K P K K W N F N W W K F N P D W F K K W D N W K D N K F F W N W P N K Z N P K P W N N W K K N P W K K F K F W N N W K W P F W P N N P K W W D K D N F D K Z D D N D K P P K N D D F K K K F N K F W Z P F W D D N W P P D F P D Z W P D W W F D P D K F P D K D F P W K Z W D D N W F N K D F N F N W W D D N K F K K W W F K K K P D W F F D W W D N W F W W N K W P P P W W D P K D K D W K N D D Z K D F F D P W F W F D D K W D N D P N P F P P F K N N P K F K N F N F K D W W K F D D N F W K D K N P F N W F P K Z N K N F W W P D P W F F N W F D F F K F D P D F F K W N D N P K N N K K W F P K D P K D N D F F K K P P N W P K F P N W P D F N K K W K W W F N W F K P D K D K P P F P F P F D D N F D D K W K F N F F N K W F D F P D D D P K K P P D N N W N F F P N W P F W N F W D N K W W Z Z P P N W D W K F N D D K K K W N F P K F P P K P W D N F P W P K K P D N N D K K K F Z N K F K K F W W W K K W F K W K F N F D P K W W W F P D P D Z K N W D K F K N D W K N K W W D W K D D K N D N W F F P F N P N N D F F D W D W K W K W N W F P K D K F F N N P P D F P W D N K Z D K P W D K P K F F N D F D P N N F N F D D D F F P D D N W Z F W K W D W D P D N D N P F Z F P P W N W F N W W N Z P P D W K K F P P P P D K D D D P P D Z D P P K D Z F F D K P W N P F P D F N K K K W W W W K F D W D W K N D F N Z D K P P D D K K P K P K P F K N W P P K P F W K K P P F N N K W D P W K P P N D D K W D P P W N N F W D W D P W K F F N K P K P W P F W D P W F W D D F K K F K K F N N K D F K W W P D W N W D N P P K P F N P F F F W W W K P W N W D D N W D F P W D P N N F W F N N F F D P P W D P D F F Z N D N W P K F D W D W N D W F K P K K N F W W N W D K F K K W N W K P W P W K K W K N W P K F P F D N F K K W W N K D N N W D F F D W P D P P D K W K K F D F N W N K F D N K N F W D D F W W N P P P W D P W P D K W N D P K K F K N P P K W K N F P F K D P P D F N P W P P F P W K F W N F P K W P P N P K F W Z P W P K K F D D P N D D F N K N P K K F W D W D K Z P K K P W W Z N W P D F P P F K F N P W K N D K K N F W F K D K D P F N F K F F P P N K F W K W N P N P Z D F W K N W W P P N W F N F W K D F D F N P P F F P P N W K N D K F N D P N P F W K P F N N F K F F N W F P N W W F W K K F Z N W K W P F W K F F D W F F F D K W P D D D P K N P F N D P F D F F F N N N W D D D D N W F K N D D N N P N N P F N W D P N D W D N D D F N W N P D N K D D F F K N N P N N K F F W D F W K P N F P D P D K F N W F N W F K K K P D N N K F K D K N K W W W N N K D P D D D F K N N D D K P K W W W D W P K K F P P K N N P D D F P F D N D F W W K K N K D D D Z D F D F P W F K K Z F N K K W D K D W D F P W D N K D K D D W D F F N P N P K W F W D Z F F D N D D N W N N W D N P F K K K P K N F K N W P P W P F D F N N N W D W W F K W P D F F D N P W K K F W N K P W D P F W K D F D N K P F N W K D W D K F Z W P W W D F W W P D D N D P N K W N F P F W K W N W F P K N D W N K D F F P F K D F Z W N D F D D N D K P W K F N N P P W P P F D W F N K K F W F P F P P K Z P W K P W N F N D W W W W W Z N K W K F W N F W F W F F F D W D N N P K D F F D W F K F W Z D K Z N N F P F K F N F N N F K P D K N W K P W F K K D D P W F K P F D F W N Z K W K D D P Z F F F P D P P N P W W P K D N D N W W N D K P D W D F W W F W P Z W F F W K D D W F P D D P F N W K P N N N D P W D P F D F F K N W D K W P W K P F F K P W K F W K N P W F K F K K N W W D P N N D D F K F P K W W F K W N W N N D K F W N P W K K K F D P K W N D D D F F F P F F F K F D W N K N F D D N F F K P P P D W D K Z K F P W N W N N W W Z F K K N D P K K D N K D P W D K K D P F W W D D P W P D N F K P Z K N F K W N N P W P D K P K W P F P P N D F K P N D W K F K K W P F F F P W F W P K K W N N N P K K D F K W K N D D D K P F K W K K K K W D W P D D P F D W D D W D F F F P D P K W D W K D D P D K W D F N K F N D N K K K K N D F N K D F N P D P D K F W F P K K P W D D P W D N P F F N K W D D K K K K W D D D W Z N W D K W N D W N P

输出

复制
FP
DEAD
P
K D
P K
D D

说明

样例1说明:第一回合主猪没有目标可以表敌意;接下来忠猪使用了3张南猪入侵,主猪掉了3点体力,并认为该角色为类反猪,3号角色尽管手里有无懈可击,但是因为自己未表明身份,所以同样不能对自己用,乖乖掉3点体力;下一回合反猪无牌可出;接下来主猪对着类反猪爆发,使用4张决斗,忠猪死亡,结果主猪弃掉所有牌;下来反猪摸到一张杀直接杀死主猪获胜。

数据说明:一共20组测试数据,每个点5分。10%的数据没有锦囊牌,另外20%的数据没有无懈可击。