Caso # | Resultado | Tiempo | Memoria |
---|---|---|---|
#1 |
Correcto
|
0.004 s | 2 KBi |
#2 |
Correcto
|
0.006 s | 13 KBi |
#3 |
Correcto
|
0.003 s | 20 KBi |
#4 |
Correcto
|
0.004 s | 2 KBi |
#5 |
Correcto
|
0.004 s | 14 KBi |
#6 |
Correcto
|
0.007 s | 14 KBi |
#7 |
Correcto
|
0.005 s | 9 KBi |
#8 |
Correcto
|
0.004 s | 34 KBi |
#9 |
Correcto
|
0.003 s | 0 KBi |
#10 |
Correcto
|
0.004 s | 1 KBi |
#11 |
Correcto
|
0.002 s | 2 KBi |
#12 |
Correcto
|
0.005 s | 3 KBi |
#13 |
Correcto
|
0.002 s | 13 KBi |
#14 |
Correcto
|
0.005 s | 16 KBi |
#15 |
Correcto
|
0.003 s | 0 KBi |
#16 |
Correcto
|
0.002 s | 2 KBi |
#17 |
Correcto
|
0.027 s | 1 KBi |
#18 |
Correcto
|
0.029 s | 4 KBi |
#19 |
Correcto
|
0.039 s | 7 KBi |
#20 |
Correcto
|
0.027 s | 3 KBi |
#21 |
Correcto
|
0.036 s | 4 KBi |
#22 |
Correcto
|
0.046 s | 9 KBi |
#23 |
Correcto
|
0.025 s | 5 KBi |
#24 |
Correcto
|
0.023 s | 1 KBi |
// #include <bits/stdc++.h> using namespace std; #define INF 1000000000 #define MOD 1000000007 #define PI 3.14159265 #define EPS 1e-9 #define Pi acos(-1.0) typedef pair<int, int> ii; typedef long long ll; typedef vector<ll> vll; typedef pair<ll,ll> pll; #define forr(i,a,b) for(int i=(a); i<(b); i++) #define clean(arr,val) memset(arr,val,sizeof(arr)) #define forn(i,n) forr(i,0,n) #define PB push_back typedef vector<int> vi; typedef vector<ii> vii; typedef vector<pll> vpll; /*CODE START HERE*/ int n; ll ans; vi vec; // // N^2 // void sol(){ // ll aux = 0; // forn(i,n){ // aux = 0; // forr(j,i,n){ // aux += vec[j]; // ans = max(aux,ans); // } // } // } // n log n ll solinMiddle(int l, int m, int r){ ll sumL, sumR, aux; sumL = sumR = -INF; aux = 0; for(int i = m; i >= l; i--){ aux += vec[i]; sumL = max(aux,sumL); } aux = 0; for(int i = m+1; i <= r; i++){ aux += vec[i]; sumR = max(sumR, aux); } //cout << "SOL IN MIDDE FOR " << l << " " << m << " " << r << " = " << max(sumR, max(sumL, sumR+sumL)) << "\n"; return sumR+sumL; } ll sol(int l, int r){ //cout << "NOW ON " << l << " " << r << "\n"; if(l == r){ return vec[l]; } int m = (l+r)/2; return max(sol(l,m),max(solinMiddle(l,m,r),sol(m+1,r))); } int main(){ ios::sync_with_stdio(0); cin >> n; vec.assign(n,0); forn(i,n){ cin >> vec[i]; } ans = -INF; ans = sol(0, n-1); // sol n log n cout << ans << "\n"; return 0; }