#P1164. 小A点菜

    ID: 1982 远端评测题 1000ms 512MiB 尝试: 3 已通过: 3 难度: 2 上传者: 标签>动态规划 DP搜索洛谷原创背包 DP

小A点菜

题目背景

uim 神犇拿到了 uoi 的 ra(镭牌)后,立刻拉着基友小 A 到了一家……餐馆,很低端的那种。

uim 指着墙上的价目表(太低级了没有菜单),说:“随便点”。

题目描述

不过 uim 由于买了一些书,口袋里只剩 MM(0<M10000)(0 < M \le 10000)

餐馆虽低端,但是菜品种类不少,有 NN(1N100)(1 \le N \le 100),第 ii 种卖 aia_i(0<ai1000)(0 < a_i \le 1000)。由于是很低端的餐馆,所以每种菜只有一份。

小 A 奉行“不把钱吃光不罢休”的原则,所以他点单一定刚好把 uim 身上所有钱花完。他想知道有多少种点菜方法。

由于小 A 肚子太饿,所以最多只能等待 11 秒。

输入格式

第一行两个整数 NNMM,分别表示菜品种类和 uim 身上的钱数。

第二行 NN 个正整数 aia_i(可能有重复),用空格隔开,分别表示每种菜的价格。

输出格式

一个正整数,表示点菜方案数,保证答案的范围在 [0,2311][0,2^{31}-1] 之内(不超过 C/C++的 int 范围)。

4 4
1 1 2 2

3

提示

2020.8.29,增添一组 hack 数据 by @yummy