//Normal-2 #define _GLIBCXX_DEBUG #define ll long long #include using namespace std; using Graph = vector>; void p(auto a){ cout << a; } void ps(auto a){ cout << a << " "; } void ps(){ cout << " "; } void pl(auto a){ cout << a << endl; } void pl(){ cout << endl; } void fix15(){ cout << fixed << setprecision(15); } void YES(){ pl("YES"); } void NO(){ pl("NO"); } void Yes(){ pl("Yes"); } void No(){ pl("No"); } void yes(){ pl("yes"); } void no(){ pl("no"); } //Normal-2 int main(){ int N, K; cin >> N >> K; vector X(3e5, 1e9+1); for(int i = 0; i < N; i++) cin >> X[i]; sort(X.begin(), X.end()); for(int i = 0; i <= N; i++){ if(K < X[i]){ ps(i); pl(K); return 0; } K -= X[i]; } }