#include <bits/stdc++.h>
using namespace std;
#define int long long int
#define double long double
#define print(a) for(auto x : a) cout << x << " "; cout << endl
inline int power(int a, int b) {
int x = 1;
while (b) {
if (b & 1) x *= a;
a *= a;
b >>= 1;
}
return x;
}
const int M = 1000000007;
const int N = 3e5+9;
const int INF = 2e9+1;
const int LINF = 2000000000000000001;
//_ ***************************** START Below *******************************
vector<int> a;
int getCost(int n, int k){
vector<int> cost(n);
for(int i=0; i<n; i++){
cost[i] = a[i] + (i+1)*k; // 1 based indexing
}
sort(begin(cost), end(cost));
int totalCost = 0;
for(int i=0; i<k; i++){
totalCost += cost[i];
}
return totalCost;
}
bool isPossible(int n, int S, int mid){
vector<int> cost(n);
for(int i=0; i<n; i++){
cost[i] = a[i] + (i+1)*mid;
}
sort(begin(cost), end(cost));
int totalCost = 0;
for(int i=0; i<mid; i++){
totalCost += cost[i];
}
return totalCost <= S;
}
pair<int,int> consistency(int n, int S){
int s = 0, e = n;
while(s<e){
int mid = s + (e-s+1)/2;
if(isPossible(n, S, mid)){
s = mid;
}
else e = mid-1;
}
return {e, getCost(n, e)};
}
void solve() {
int n, S;
cin>>n >> S;
a.resize(n);
for(int i=0; i<n; i++) cin >> a[i];
auto ans1 = consistency(n, S);
cout << ans1.first << " " << ans1.second << endl;
}
int32_t main() {
ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
int t = 1;
// cin >> t;
while (t--) {
solve();
}
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNkZWZpbmUgaW50ICAgICAgICAgICAgICBsb25nIGxvbmcgaW50CiNkZWZpbmUgZG91YmxlICAgICAgICAgICBsb25nIGRvdWJsZQojZGVmaW5lIHByaW50KGEpICAgICAgICAgZm9yKGF1dG8geCA6IGEpIGNvdXQgPDwgeCA8PCAiICI7IGNvdXQgPDwgZW5kbAppbmxpbmUgaW50IHBvd2VyKGludCBhLCBpbnQgYikgewogICAgaW50IHggPSAxOwogICAgd2hpbGUgKGIpIHsKICAgICAgICBpZiAoYiAmIDEpIHggKj0gYTsKICAgICAgICBhICo9IGE7CiAgICAgICAgYiA+Pj0gMTsKICAgIH0KICAgIHJldHVybiB4Owp9CgoKY29uc3QgaW50IE0gPSAxMDAwMDAwMDA3Owpjb25zdCBpbnQgTiA9IDNlNSs5Owpjb25zdCBpbnQgSU5GID0gMmU5KzE7CmNvbnN0IGludCBMSU5GID0gMjAwMDAwMDAwMDAwMDAwMDAwMTsKCi8vXyAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiBTVEFSVCBCZWxvdyAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCgp2ZWN0b3I8aW50PiBhOwoKaW50IGdldENvc3QoaW50IG4sIGludCBrKXsKCXZlY3RvcjxpbnQ+IGNvc3Qobik7Cglmb3IoaW50IGk9MDsgaTxuOyBpKyspewoJCWNvc3RbaV0gPSBhW2ldICsgKGkrMSkqazsgLy8gMSBiYXNlZCBpbmRleGluZwoJfQoJCglzb3J0KGJlZ2luKGNvc3QpLCBlbmQoY29zdCkpOwoJCglpbnQgdG90YWxDb3N0ID0gMDsKCWZvcihpbnQgaT0wOyBpPGs7IGkrKyl7CgkJdG90YWxDb3N0ICs9IGNvc3RbaV07Cgl9CgkKCXJldHVybiB0b3RhbENvc3Q7IAp9Cgpib29sIGlzUG9zc2libGUoaW50IG4sIGludCBTLCBpbnQgbWlkKXsKCXZlY3RvcjxpbnQ+IGNvc3Qobik7Cglmb3IoaW50IGk9MDsgaTxuOyBpKyspewoJCWNvc3RbaV0gPSBhW2ldICsgKGkrMSkqbWlkOwoJfQoJCglzb3J0KGJlZ2luKGNvc3QpLCBlbmQoY29zdCkpOwoJaW50IHRvdGFsQ29zdCA9IDA7Cglmb3IoaW50IGk9MDsgaTxtaWQ7IGkrKyl7CgkJdG90YWxDb3N0ICs9IGNvc3RbaV07Cgl9CglyZXR1cm4gdG90YWxDb3N0IDw9IFM7IAp9CgpwYWlyPGludCxpbnQ+IGNvbnNpc3RlbmN5KGludCBuLCBpbnQgUyl7CgoJaW50IHMgPSAwLCBlID0gbjsKCXdoaWxlKHM8ZSl7CgkJaW50IG1pZCA9IHMgKyAoZS1zKzEpLzI7CgkJaWYoaXNQb3NzaWJsZShuLCBTLCBtaWQpKXsKCQkJcyA9IG1pZDsKCQl9CgkJZWxzZSBlID0gbWlkLTE7Cgl9CgkKCXJldHVybiB7ZSwgZ2V0Q29zdChuLCBlKX07Cgp9CgoKCgoKCgoKdm9pZCBzb2x2ZSgpIHsKICAgIAogICAgaW50IG4sIFM7CiAgICBjaW4+Pm4gPj4gUzsKICAgIAogICAgYS5yZXNpemUobik7CiAgICBmb3IoaW50IGk9MDsgaTxuOyBpKyspIGNpbiA+PiBhW2ldOwogICAgCiAgICBhdXRvIGFuczEgPSBjb25zaXN0ZW5jeShuLCBTKTsKCQoJY291dCA8PCBhbnMxLmZpcnN0IDw8ICIgIiA8PCBhbnMxLnNlY29uZCA8PCBlbmRsOwoKfQoKCgoKCmludDMyX3QgbWFpbigpIHsKICAgIGlvc19iYXNlOjpzeW5jX3dpdGhfc3RkaW8oMCk7IGNpbi50aWUoMCk7IGNvdXQudGllKDApOwoKICAgIGludCB0ID0gMTsKICAgIC8vIGNpbiA+PiB0OwogICAgd2hpbGUgKHQtLSkgewogICAgICAgIHNvbHZlKCk7CiAgICB9CgogICAgcmV0dXJuIDA7Cn0=