#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace std;
using namespace __gnu_pbds;
using ll = long long;
using ld = long double;
#define all(x) x.begin(),x.end()
#define v(x) vector<x>
#define nl '\n'
#define fxd(x) fixed << setprecision(x)
template<class t> using ordered_set = tree<t, null_type, less<t>, rb_tree_tag, tree_order_statistics_node_update>;
template<class t> using ordered_multiset = tree<t, null_type, less_equal<t>, rb_tree_tag, tree_order_statistics_node_update>;
int main()
{
ios_base::sync_with_stdio(false); cin.tie(nullptr); cout.tie(nullptr);
int n; cin >> n;
v(ll) arr(n+1);
for (int i = 1; i <= n; i++)
{
cin >> arr[i];
}
v(ll) prefsum(n+1,0);
for (int i = 1; i <= n; i++)
{
prefsum[i] = prefsum[i-1] + arr[i];
}
v(ll) minprefsum(n+1,0);
for (int i = 1; i <= n; i++)
{
minprefsum[i] = min(prefsum[i],minprefsum[i-1]);
}
ll mx = -1e17;
for (int i = 1; i <= n; i++)
{
if(prefsum[i] == minprefsum[i])
{
mx = max(mx,arr[i]);
}
else
{
mx = max(mx,prefsum[i]-minprefsum[i]);
}
}
cout << mx;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNpbmNsdWRlIDxleHQvcGJfZHMvYXNzb2NfY29udGFpbmVyLmhwcD4KI2luY2x1ZGUgPGV4dC9wYl9kcy90cmVlX3BvbGljeS5ocHA+Cgp1c2luZyBuYW1lc3BhY2Ugc3RkOwp1c2luZyBuYW1lc3BhY2UgX19nbnVfcGJkczsKdXNpbmcgbGwgPSBsb25nIGxvbmc7CnVzaW5nIGxkID0gbG9uZyBkb3VibGU7CgojZGVmaW5lIGFsbCh4KSAgeC5iZWdpbigpLHguZW5kKCkKI2RlZmluZSB2KHgpIHZlY3Rvcjx4PgojZGVmaW5lIG5sICdcbicKI2RlZmluZSBmeGQoeCkgZml4ZWQgPDwgc2V0cHJlY2lzaW9uKHgpCnRlbXBsYXRlPGNsYXNzIHQ+IHVzaW5nIG9yZGVyZWRfc2V0ID0gdHJlZTx0LCBudWxsX3R5cGUsIGxlc3M8dD4sIHJiX3RyZWVfdGFnLCB0cmVlX29yZGVyX3N0YXRpc3RpY3Nfbm9kZV91cGRhdGU+Owp0ZW1wbGF0ZTxjbGFzcyB0PiB1c2luZyBvcmRlcmVkX211bHRpc2V0ID0gdHJlZTx0LCBudWxsX3R5cGUsIGxlc3NfZXF1YWw8dD4sIHJiX3RyZWVfdGFnLCB0cmVlX29yZGVyX3N0YXRpc3RpY3Nfbm9kZV91cGRhdGU+OwoKCmludCBtYWluKCkKewogICAgaW9zX2Jhc2U6OnN5bmNfd2l0aF9zdGRpbyhmYWxzZSk7IGNpbi50aWUobnVsbHB0cik7IGNvdXQudGllKG51bGxwdHIpOwogICAgaW50IG47IGNpbiA+PiBuOwogICAgdihsbCkgYXJyKG4rMSk7CiAgICBmb3IgKGludCBpID0gMTsgaSA8PSBuOyBpKyspCiAgICB7CiAgICAgICAgY2luID4+IGFycltpXTsKICAgIH0KICAgIHYobGwpIHByZWZzdW0obisxLDApOwogICAgZm9yIChpbnQgaSA9IDE7IGkgPD0gbjsgaSsrKQogICAgewogICAgICAgIHByZWZzdW1baV0gPSBwcmVmc3VtW2ktMV0gKyBhcnJbaV07CiAgICB9CiAgICB2KGxsKSBtaW5wcmVmc3VtKG4rMSwwKTsKICAgIGZvciAoaW50IGkgPSAxOyBpIDw9IG47IGkrKykKICAgIHsKICAgICAgICBtaW5wcmVmc3VtW2ldID0gbWluKHByZWZzdW1baV0sbWlucHJlZnN1bVtpLTFdKTsKICAgIH0KICAgIGxsIG14ID0gLTFlMTc7CiAgICBmb3IgKGludCBpID0gMTsgaSA8PSBuOyBpKyspCiAgICB7CiAgICAgICAgaWYocHJlZnN1bVtpXSA9PSBtaW5wcmVmc3VtW2ldKQogICAgICAgIHsKICAgICAgICAgICAgbXggPSBtYXgobXgsYXJyW2ldKTsKICAgICAgICB9CiAgICAgICAgZWxzZQogICAgICAgIHsKICAgICAgICAgICAgbXggPSBtYXgobXgscHJlZnN1bVtpXS1taW5wcmVmc3VtW2ldKTsKICAgICAgICB9CiAgICB9CiAgICBjb3V0IDw8IG14OwogICAgCn0=