A7946.大富翁游戏

普及-

官方

通过率:0%

时间限制:1.00s

内存限制:128MB

题目描述

小码君和小码酱在玩大富翁游戏。这个大富翁游戏与一般的大富翁游戏在玩法上有略微区别

大富翁游戏是由 nn 个格子组成,编号逆时针地从 1,2,...,n1,2,...,n,构成了一个环。小码君和小码酱起始在编号为 11 的格子。小码君和小码酱最开始都有 mm 元资金。每一个回合,小码君先投掷骰子,再是小码酱投掷骰子。每一方行动时,设骰子最上面的数字为 kk,则行动方逆时针移动 kk 步。在移动的过程中,行动者所经过的每一个格子应当都分为两种情况:

  • 如果当前格子(假设编号为 ii)上有建筑物,而且建筑物是自己的,则行动方可以获得额外的 aia_i 元资金。
  • 如果当前格子上有建筑物,但是建筑物是对方的,则行动方要将自己的 aia_i 元资金转移给对方。

在行动结束后亦有两种情况:

  • 如果当前格子(设编号为 ii)上没有建筑物,则行动方可以选择花费 Ci,0C_{i,0} 元资金(前提要求行动者当前的资金大于等于 Ci,0C_{i,0})搭建建筑物,此时 aia_i 被初始化为 Ci,0C_{i,0}
  • 如果当前格子的建筑物是行动方的,假设当前是一座 jj 等级的建筑物,那么行动方可以选择用 Ci,jC_{i,j} 元为建筑物升级,功效是使得 aiai+Ci,ja_i \gets a_i+C_{i,j}。这里,Ci,jC_{i,j} 表示将第 ii 个格子上的第 jj 等级的建筑物升级到第 j+1j+1 等级的建筑物所需花费的资金。同一回合内可以多次升级建筑。特别地,建筑物的等级上限为 LL。如果当前建筑物等级已经到达上限则无法升级。
  • 在所有建筑操作结束后,操作权转移给另一方。

两人都操作完一轮回合后,圆环上的每个建筑物都会提供给拥有者资金,具体来说,第 ii 格上的建筑物会给其拥有者提供 did_i 的资金。游戏结束当且仅当存在一个人在它行动过程中或者结束时的资金为负数。此时这个人成为输家(换而言之,允许中途过程资金为 00)。

给定小码君和小码酱的 qq 个回合的每次操作,请问谁会是输家呢?

输入格式

第一行输入四个正整数 n,m,q,Ln,m,q,L,表示格子数、初始资金、回合次数和建筑物等级上限。

第二行开始,往下 nn 行,每行输入 LL 个正整数,表示 Ci,jC_{i,j},其中 jj 是从 00L1L-1

(n+2)(n+2) 行输入 nn 个正整数表示 did_i

(n+3)(n+3) 行开始,往下若干行,每行只会有两种可能的情况:

  • 1 k\text{1 k},表示当前行动方投掷了骰子,最上面的点数是 kk。之后行动者会逆时针移动 kk 步。
  • 2 k\text{2 k},表示当前行动方在当前位置建造或者升级了建筑物共 kk 次。
    • 在此过程中,当前位置已经有了对方建筑物则忽略此操作;
    • 如果资金不够升级 kk 次,则只升级到资金允许范围内的最高等级;
    • 在此过程中,如果进行下一次升级,建筑物等级超过 LL,则后续的所有升级忽略处理。

特别地,规定除了第一次外,每次 1 k\text{1 k} 操作出现时意味着行动者的切换。也就是说,第一次输入 1 k\text{1 k} 操作时,行动方是小码君,第二次是小码酱,第三次是小码君……以此类推。值得注意的是,2 k\text{2 k} 操作出现并不会切换行动者。

此外,保证每个 1\mathbf{1} 操作后面最多跟随 1\mathbf{1}2\mathbf{2} 操作

输出格式

如果已经分出了输赢,则输出谁是输家(如果小码君输,则输出 JUN\text{JUN};如果小码酱输,则输出 JIANG\text{JIANG});

如果没有分出输赢,则按照先小码君,后小码酱的顺序输出她们现在有的资金数。

输入输出样例

  • 输入#1

    6 40 5 3
    10 20 30
    15 25 35
    6 8 12
    6 12 18
    8 16 24
    8 12 40
    1 2 3 4 5 6
    1 4
    2 3
    1 2
    2 5
    1 3
    1 2
    2 1
    1 5
    2 3
    1 3
    2 4
    1 4
    1 6
    2 2
    1 3
    2 1
    1 3
    2 1

    输出#1

    JIANG
  • 输入#2

    6 9961 5 3
    10 20 30
    15 25 35
    6 8 12
    6 12 18
    8 16 24
    8 12 40
    1 2 3 4 5 6
    1 4
    2 3
    1 2
    2 5
    1 3
    1 2
    2 1
    1 5
    2 3
    1 3
    2 4
    1 4
    1 6
    2 2
    1 3
    2 1
    1 3
    2 1

    输出#2

    10099 9946

说明/提示

【样例解释 1】

第一回合,小码君首先走 44 步,到达编号为 55 的格子,同时尝试建造与升级 33 次第五个格子的建筑物,但是 C5,0+C5,1+C5,2=48C_{5,0}+C_{5,1}+C_{5,2}=48,所以只能把建筑物造到 22 级。此时小码君手上还有 1616 元。
接着小码酱走了两步,到达编号为 33 的格子,同时尝试建造与升级 55 次第三个格子的建筑物,C3,0+C3,1+C3,2=26C_{3,0}+C_{3,1}+C_{3,2}=26,而造五次会超过等级上限 LL,因此只能升到 33 次,此时小码酱手上还有 1414 元。
回合结束后每个建筑物都会提供给拥有者 did_i 的资金,也就是说小码君此时手上有 2121 元,小码酱手上有 1717 元。
第二回合,小码君首先走 33 步,到达编号为 22 的格子。小码酱接着走 22 步,到达编号为 55 的格子,收取 aia_i 元。而 ai=24a_i=24,因此小码酱的资金被扣成了负数,从而输出 JIANG\text{JIANG}

【样例解释 2】

仅在初始资金与第一组样例有一定变化,因此在这些回合中无法决出胜负,因此输出两人手上现有的资金。

【数据范围】

对于所有数据,保证 1n,L1001 \leq n,L\leq 1001q1041 \leq q \leq 10^41m,Ci,j,di1061 \leq m,C_{i,j},d_i \leq 10^61k1031 \leq k \leq 10^3(你可以不必在意怎么获得一个 kk 面的骰子)。数据保证 11 操作次数恰好为 2×q2\times q

首页