#C1040. 小张点菜

小张点菜

题目描述

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

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

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

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

输入格式

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

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

输出格式

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

输入输出样例 #1

输入 #1

4 4
1 1 2 2

输出 #1

3