#include<iostream>
#include<algorithm>
using namespace std;
int N, H[20000];
long long S, B;
int main()
{
int j = 0;
cin >> N >> B;
for (int i = 0; i < N; i++)
cin >> H[i];
sort(H, H + N);
for (int i = N - 1; i >= 0; i--, j++)
{
S += H[i];
if (S >= B)
break;
}
cout << j+1;
return 0;
}