#D. 【科大国创杯初中组2025】抽卡

    传统题 文件IO:card 1000ms 1024MiB

【科大国创杯初中组2025】抽卡

该比赛已结束,您无法在比赛模式下递交该题目。您可以点击“在题库中打开”以普通模式查看和递交本题。

P12251 [科大国创杯初中组 2025] 抽卡

题目背景

目前测试数据为大样例,会在获取测试数据后重新评测所有提交记录。

题目描述

小可可正在和波特玩卡牌游戏。

这个游戏有 mm 种卡牌。种类为 xx 的卡牌价值也为 xx。首先,波特一共会进行 nn 次抽卡来确定游戏的牌堆。第 ii 次,会有 aia_i 种新的卡牌解锁。也就是说如果第 ii 次抽卡之前第 1s1 \sim s 种卡牌解锁了,那么第 ii 次时第 1s+ai1 \sim s + a_i 种卡牌都会解锁。保证 i=1nai=m\displaystyle \sum_{i=1}^{n} a_i = m。初始没有卡牌解锁。

在第 ii 次抽卡时,波特会等概率随机选择一种已经被解锁的卡牌,并且取出两张这个种类的卡牌,依次放在现在所有牌的右边。在 nn 次抽卡结束后,一共会有 2n2n 张卡牌从左向右排成一排作为游戏的牌堆。小可可知道这 2n2n 张卡牌各自的价值。

现在,小可可和波特会轮流从这个牌堆中进行抽卡,直到抽完所有卡牌,小可可先手。波特每次抽卡只会取走当前牌堆中最左边的卡牌。而小可可可以在当前牌堆中任意选择一张取走。小可可希望抽卡结束后自己手中的卡牌价值总和最大。他想要知道,如果自己采取最优策略,那么期望得到的价值是多少呢?你只需要告诉他答案对 109+710^9 + 7 取模的结果就行。

关于期望:设离散型随机变量 XX 的概率分布为 pi=P{X=xi}p_i = P\{X = x_i\},那么我们称 E=xipiE = \sum x_i p_i 的值为 XX 的期望。不过在本题中,由于每种可能的情况出现概率相等,所以你可以简单地理解为所有方案中小可可得到的卡牌价值总和除以总方案数。

关于有理数取余:不难发现答案一定是一个有理数,设其为 C=ABC = \frac{A}{B},其中 A,BA, B 互质,你需要输出 Cmod1000000007C \bmod 1000000007 的值。这个值被定义为 BxA(mod1000000007)Bx \equiv A \pmod {1000000007} 的最小非负整数解。

输入格式

第一行两个整数 n,mn, m

第二行 nn 个整数表示 aa

输出格式

输出一行一个整数表示答案。

输入输出样例 #1

输入 #1

2 3
1 2

输出 #1

4

说明/提示

样例 1 解释

11 次,解锁的卡牌种类只有 11,于是波特会取出两张 11 卡牌。

22 次,解锁的卡牌种类有 1,2,31, 2, 3。波特会随机取出某一种类的两张卡牌。于是有如下三种可能:

  • 牌堆中的卡牌从左到右分别为:1,1,1,11, 1, 1, 1,概率为 13\frac{1}{3},小可可可以获得的最大价值为 1+1=21 + 1 = 2
  • 牌堆中的卡牌从左到右分别为:1,1,2,21, 1, 2, 2,概率为 13\frac{1}{3},小可可可以获得的最大价值为 2+2=42 + 2 = 4
  • 牌堆中的卡牌从左到右分别为:1,1,3,31, 1, 3, 3,概率为 13\frac{1}{3},小可可可以获得的最大价值为 3+3=63 + 3 = 6

于是答案为 $2 \times \frac{1}{3} + 4 \times \frac{1}{3} + 6 \times \frac{1}{3} = 4$。

数据规模与约定

测试点编号 nn \leq mm \leq 特殊性质
121 \sim 2 33
363 \sim 6 88
797 \sim 9 500500 500500 a1=ma_1 = m
101310 \sim 13
141514 \sim 15 10510^5
161916 \sim 19 100100 10910^9
202120 \sim 21 500500 a1=ma_1 = m
222522 \sim 25

对于 100%100\% 的数据,满足 $1 \leq n \leq 500, 1 \leq m \leq 10^9, 0 \leq a_i \leq m$。保证 i=1nai=m\displaystyle \sum_{i=1}^{n} a_i = m 并且 a1>0a_1 > 0

2025年"科大国创杯"-[ACSP-J]-估分

未参加
状态
已结束
规则
OI
题目
4
开始于
2025-4-21 18:00
结束于
2025-4-30 2:00
持续时间
4 小时
主持人
参赛人数
0