CFCF2192F.Fish Fight
省选/NOI-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
在一个池塘中,有 n 条鱼排成一排。对于每条鱼 i,其体型为 ai,任何吃掉它的鱼体型将增加 bi。
Alice 选择第 x 条鱼,Bob 选择第 y 条鱼。两人轮流操作,首先由 Alice 所选的鱼行动。每位玩家的操作回合中,其所选的鱼当前体型为 p。这条鱼会吃掉一条相邻且体型不超过自己的鱼 q。如果存在多条满足条件的鱼,则等概率地随机选一条吃掉。吃掉后体型增加被吃鱼的 bi。
如果到了某条鱼回合开始时无法吃掉任意相邻的鱼,则该鱼被其相邻的鱼吞食(位于端点的鱼只会被唯一的邻居吃,内部的鱼会被任一邻居吃)。如果 Alice 的鱼被吃掉(无论是被 Bob 的鱼还是被其他邻居鱼吃掉),Alice 立即输掉。同理,Bob 的鱼被吃掉,Bob 立即输掉。
现已知 Alice 和 Bob 各自选择的鱼,计算 Alice 获胜的概率,对 109+7 取模。
更正式地说,设 M=109+7。结果可表示为不可约分数 qp,且 q≡0(modM)。请输出 pq−1modM,即唯一满足 0≤x<M 且 xq≡p(modM) 的整数 x。
输入格式
每个测试点包含若干组测试数据。第一行为测试用例数 t(1≤t≤500)。
每组测试数据第一行为一个整数 n(2≤n≤3000),表示池塘中的鱼的数量。
第二行包含两个整数 x 和 y(1≤x,y≤n;x=y),表示 Alice 和 Bob 分别选择的鱼的编号。
第三行包含 n 个整数 a1,a2,…,an(1≤ai≤109),分别表示每条鱼的体型。
第四行包含 n 个整数 b1,b2,…,bn(0≤bi≤109),分别表示每条鱼被吃掉后可增加的体型。
保证所有测试数据中 n 的总和不超过 3000。
输出格式
对于每组测试数据,输出一行一个整数,表示 Alice 获胜的概率对 109+7 取模的结果。
输入输出样例
输入#1
6 2 1 2 1 2 1 1 2 1 2 2 1 1 1 3 2 3 1 4 4 0 1 1 5 4 2 2 6 5 5 3 1 2 1 3 2 7 3 5 1 1 1 1 1 1 1 0 0 0 0 0 0 1 10 8 3 2 5 9 3 8 4 5 6 2 7 1 3 5 2 7 3 4 2 2 3
输出#1
0 1 500000004 750000006 375000003 687500005
说明/提示
在第一个测试点,Alice 的鱼无法吃到任何相邻的鱼,所以 Alice 一定会输。
在第二个测试点,Alice 的鱼只有一个相邻的鱼,就是 Bob 的鱼,且 Alice 的鱼体型大于等于 Bob 的鱼体型,因此 Alice 必胜。
在第三个测试点,第一回合 Alice 选择的鱼可以吃掉两条相邻的鱼。
情况 1:吃掉第 3 条鱼(Bob 的鱼),Alice 获胜。
情况 2:吃掉第 1 条鱼。接下来 Alice 的鱼体型变为 a2+b1=4+0=4。这样第二回合 Bob 的鱼会马上吃掉 Alice 的鱼,Alice 输。
两种情况发生的概率均为 21,所以 Alice 获胜的概率是 0.5。
在第四个测试点里,Alice 获胜的概率是 0.75。