#include <iostream>
#include <vector>
using namespace std;
// Fast I/O Macro
void Mbappe() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
}
void solve() {
int n;
long long d;
if (!(cin >> n >> d)) return;
vector<long long> a(n);
for (int i = 0; i < n; i++) {
cin >> a[i];
}
// Function to check if we can achieve a final height of 'mid'
auto check = [&](long long mid) {
long long req = mid;
// Moving backwards
for (int i = n - 1; i >= 0; i--) {
if (req >= a[i]) {
req += a[i];
}
}
return req <= d; // Can we do this within our budget?
};
long long low = 0, high = d, ans = 0;
// Binary Search on the final height
while (low <= high) {
long long mid = low + (high - low) / 2;
if (check(mid)) {
ans = mid; // If valid, save it and try for a higher height
low = mid + 1;
} else {
high = mid - 1; // If not valid, we need to aim lower
}
}
cout << ans << "\n";
}
int main() {
Mbappe();
// Vamoooos__ACCPTED
int t = 1;
// cin >> t; // Uncomment if the problem adds multiple test cases later
while (t--) {
solve();
}
return 0;
}
I2luY2x1ZGUgPGlvc3RyZWFtPgojaW5jbHVkZSA8dmVjdG9yPgoKdXNpbmcgbmFtZXNwYWNlIHN0ZDsKCi8vIEZhc3QgSS9PIE1hY3JvCnZvaWQgTWJhcHBlKCkgewogICAgaW9zX2Jhc2U6OnN5bmNfd2l0aF9zdGRpbyhmYWxzZSk7CiAgICBjaW4udGllKE5VTEwpOwogICAgY291dC50aWUoTlVMTCk7Cn0KCnZvaWQgc29sdmUoKSB7CiAgICBpbnQgbjsKICAgIGxvbmcgbG9uZyBkOwogICAgaWYgKCEoY2luID4+IG4gPj4gZCkpIHJldHVybjsKICAgIAogICAgdmVjdG9yPGxvbmcgbG9uZz4gYShuKTsKICAgIGZvciAoaW50IGkgPSAwOyBpIDwgbjsgaSsrKSB7CiAgICAgICAgY2luID4+IGFbaV07CiAgICB9CgogICAgLy8gRnVuY3Rpb24gdG8gY2hlY2sgaWYgd2UgY2FuIGFjaGlldmUgYSBmaW5hbCBoZWlnaHQgb2YgJ21pZCcKICAgIGF1dG8gY2hlY2sgPSBbJl0obG9uZyBsb25nIG1pZCkgewogICAgICAgIGxvbmcgbG9uZyByZXEgPSBtaWQ7CiAgICAgICAgLy8gTW92aW5nIGJhY2t3YXJkcwogICAgICAgIGZvciAoaW50IGkgPSBuIC0gMTsgaSA+PSAwOyBpLS0pIHsKICAgICAgICAgICAgaWYgKHJlcSA+PSBhW2ldKSB7CiAgICAgICAgICAgICAgICByZXEgKz0gYVtpXTsKICAgICAgICAgICAgfQogICAgICAgIH0KICAgICAgICByZXR1cm4gcmVxIDw9IGQ7IC8vIENhbiB3ZSBkbyB0aGlzIHdpdGhpbiBvdXIgYnVkZ2V0PwogICAgfTsKCiAgICBsb25nIGxvbmcgbG93ID0gMCwgaGlnaCA9IGQsIGFucyA9IDA7CiAgICAKICAgIC8vIEJpbmFyeSBTZWFyY2ggb24gdGhlIGZpbmFsIGhlaWdodAogICAgd2hpbGUgKGxvdyA8PSBoaWdoKSB7CiAgICAgICAgbG9uZyBsb25nIG1pZCA9IGxvdyArIChoaWdoIC0gbG93KSAvIDI7CiAgICAgICAgaWYgKGNoZWNrKG1pZCkpIHsKICAgICAgICAgICAgYW5zID0gbWlkOyAgICAgICAvLyBJZiB2YWxpZCwgc2F2ZSBpdCBhbmQgdHJ5IGZvciBhIGhpZ2hlciBoZWlnaHQKICAgICAgICAgICAgbG93ID0gbWlkICsgMTsKICAgICAgICB9IGVsc2UgewogICAgICAgICAgICBoaWdoID0gbWlkIC0gMTsgIC8vIElmIG5vdCB2YWxpZCwgd2UgbmVlZCB0byBhaW0gbG93ZXIKICAgICAgICB9CiAgICB9CiAgICAKICAgIGNvdXQgPDwgYW5zIDw8ICJcbiI7Cn0KCmludCBtYWluKCkgewogICAgTWJhcHBlKCk7CiAgICAvLyBWYW1vb29vc19fQUNDUFRFRAogICAgaW50IHQgPSAxOyAKICAgIC8vIGNpbiA+PiB0OyAvLyBVbmNvbW1lbnQgaWYgdGhlIHByb2JsZW0gYWRkcyBtdWx0aXBsZSB0ZXN0IGNhc2VzIGxhdGVyCiAgICB3aGlsZSAodC0tKSB7CiAgICAgICAgc29sdmUoKTsKICAgIH0KICAgIHJldHVybiAwOwp9