题目名称 2935. [HAOI 2018]奇怪的背包
输入输出 knapsack.in/out
难度等级 ★★★
时间限制 2000 ms (2 s)
内存限制 512 MiB
测试数据 10
题目来源 GravatarBenjamin 于2018-04-24加入
开放分组 全部用户
提交状态
分类标签
HAOI 动态规划 数论 数学
分享题解
通过:1, 提交:6, 通过率:16.67%
Gravatar胡嘉兴 100 1.353 s 1.77 MiB C++
Gravatar冷月星云 60 0.584 s 101.49 MiB C++
Gravatar冷月星云 0 0.000 s 0.00 MiB C++
Gravatar☭寒冰烈火☭ 0 0.002 s 0.32 MiB C++
GravatarB_Leaves 0 0.002 s 0.32 MiB C++
Gravatar梦那边的美好ET 0 0.008 s 10.79 MiB C++
本题关联比赛
HAOI 2018 Day1
2022级数学专题练习赛8
关于 奇怪的背包 的近10条评论(全部评论)
最后两个点数据有误
Gravatar胡嘉兴
2018-11-06 17:31 2楼
第一
GravatarB_Leaves
2018-07-02 10:25 1楼

2935. [HAOI 2018]奇怪的背包

★★★   输入文件:knapsack.in   输出文件:knapsack.out   简单对比
时间限制:2 s   内存限制:512 MiB

题目描述

小 $C$ 非常擅长背包问题,他有一个奇怪的背包,这个背包有一个参数 $P$,当他向这个背包内放入若干个物品后,背包的重量是物品总体积对 $P$ 取模后的结果。

现在小 $C$ 有 $n$ 种体积不同的物品,第 $i$ 种占用体积为 $V_i$,每种物品都有无限个。他会进行 $q$ 次询问,每次询问给出重量 $w_i$,你需要回答有多少种放入物品的方案,能将一个初始为空的背包的重量变为 $w_i$。注意,两种方案被认为是不同的,当且仅当放入物品的种类不同,而与每种物品放入的个数无关。不难发现总的方案数为 $2^n$。

由于答案可能很大,你只需要输出答案对 $10^9+7$ 取模的结果。

输入格式

第一行三个整数 $n,q,P$。

接下来一行 $n$ 个整数表示 $V_i$。

接下来一行 $q$ 个整数表示 $w_i$。

输出格式

输出 $q$ 行,每行一个整数表示答案。

【样例1输入】

3 3 6
1 3 4
5 2 3

【样例1输出】

5 
6
6

【样例1解释】

对于第一个询问 $5$,选择 $\{1\},\{1,3\},\{1,4\},\{3,4\},\{1,3,4\}$ 都是合法的方案。

【样例2】

点击下载样例2 

【数据范围与约定】

对于所有数据,有 $1\le n, q\le 10^6, 3\le P\le 10^9, 0\lt V_i,w_i\lt P$。

保证 $V_i$ 两两不同。