僕には、たくさんの友達がいる。どの友達も、とても小さい。
僕は、よく友達と一緒に出かける。何人かの友達をリュックに入れて、一緒に出かける。
僕は毎朝、その日一緒に出かける友達を決める。空のリュックに、1人ずつ友達を入れていく。
僕は、あまり力が強くない。だから、同時に運べる友達の重さには限界がある。
僕は、重さの限界を超えないように友達を入れていく。どの順番で入れていくかは気分次第。
僕は、入れられる友達がまだ残っている限り、入れるのを止めない。決して止めない。
……ところで、リュックに入った友達の組み合わせは、全部で何パターンあるんだろう?
N W
w1
w2
.
.
.
wn
入力の1行目には、整数N(1 ≤ N ≤ 200)と整数W(1 ≤ W ≤ 10,000)が、この順に空白区切りで書かれている。整数N は友達の数を、整数W は同時に運べる重さの限界をあらわす。重さの合計がW より大きいと運ぶことはできない。
続くN 行には、友達の重さをあらわす整数が書かれている。整数wi(1 ≤ wi ≤ 10,000)が、i 番目の友達の重さをあらわす。
最終的にリュックに入っている友達の組み合わせは何通り考えられるか。その総数を1,000,000,007 で割った余りを出力せよ。なお1,000,000,007 は素数である。
「誰もリュックに入っていない」も1通りとして数えることに注意せよ。
4 8 1 2 7 9
2
4 25 20 15 20 15
4
6 37 5 9 13 18 26 33
6