#pragma GCC optimize("Ofast")
#pragma GCC optimize("unroll-loops")
#pragma GCC optimize("inline")
#include<bits/stdc++.h>
using namespace std;
template < class T> struct cLtraits_identity{
using type = T;
}
;
template < class T> using cLtraits_try_make_signed =
typename conditional<
is_integral< T> :: value ,
make_signed< T> ,
cLtraits_identity< T>
> :: type ;
template < class T> using cLtraits_try_make_unsigned =
typename conditional<
is_integral< T> :: value ,
make_unsigned< T> ,
cLtraits_identity< T>
> :: type ;
template < class S, class T> struct cLtraits_common_type{
using tS = typename cLtraits_try_make_signed< S> :: type ;
using tT = typename cLtraits_try_make_signed< T> :: type ;
using type = typename common_type< tS,tT> :: type ;
}
;
void * wmem;
char memarr[ 96000000 ] ;
template < class S, class T> inline auto max_L( S a, T b)
- > typename cLtraits_common_type< S,T> :: type {
return ( typename cLtraits_common_type< S,T> :: type ) a >= ( typename cLtraits_common_type< S,T> :: type ) b ? a : b;
}
template < class S, class T> inline S chmin( S & a, T b) {
if ( a> b) {
a= b;
}
return a;
}
template < class S, class T> inline S chmax( S & a, T b) {
if ( a< b) {
a= b;
}
return a;
}
template < class S, class T> inline S divup_L( S a, T b) {
return ( a+ b- 1 ) / b;
}
template < class T> inline void walloc1d( T ** arr, int x, void ** mem = & wmem) {
static int skip[ 16 ] = { 0 , 15 , 14 , 13 , 12 , 11 , 10 , 9 , 8 , 7 , 6 , 5 , 4 , 3 , 2 , 1 } ;
( * mem) = ( void * ) ( ( ( char * ) ( * mem) ) + skip[ ( ( unsigned long long ) ( * mem) ) & 15 ] ) ;
( * arr) = ( T* ) ( * mem) ;
( * mem) = ( ( * arr) + x) ;
}
template < class T> inline void walloc1d( T ** arr, int x1, int x2, void ** mem = & wmem) {
walloc1d( arr, x2- x1, mem) ;
( * arr) - = x1;
}
inline int Ilog2_f_L( const int n) {
int res;
if ( n <= 0 ) {
return - 1 ;
}
res = sizeof ( int ) * 8 - __builtin_clz( n) - 1 ;
return res;
}
inline int Ilog2_f_L( const long long n) {
int res;
if ( n <= 0 ) {
return - 1 ;
}
res = sizeof ( long long ) * 8 - __builtin_clzll( n) - 1 ;
return res;
}
template < class T1> void sortI( int N, T1 a[ ] , void * mem = wmem) {
sort( a, a+ N) ;
}
template < class T1, class T2> void sortI( int N, T1 a[ ] , T2 b[ ] , void * mem = wmem) {
int i;
pair< T1, T2> * arr;
walloc1d( & arr, N, & mem) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
arr[ i] .first = a[ i] ;
arr[ i] .second = b[ i] ;
}
sort( arr, arr+ N) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
a[ i] = arr[ i] .first ;
b[ i] = arr[ i] .second ;
}
}
template < class T1, class T2, class T3> void sortI( int N, T1 a[ ] , T2 b[ ] , T3 c[ ] , void * mem = wmem) {
int i;
pair< T1, pair< T2, T3> > * arr;
walloc1d( & arr, N, & mem) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
arr[ i] .first = a[ i] ;
arr[ i] .second .first = b[ i] ;
arr[ i] .second .second = c[ i] ;
}
sort( arr, arr+ N) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
a[ i] = arr[ i] .first ;
b[ i] = arr[ i] .second .first ;
c[ i] = arr[ i] .second .second ;
}
}
template < class T1, class T2, class T3, class T4> void sortI( int N, T1 a[ ] , T2 b[ ] , T3 c[ ] , T4 d[ ] , void * mem = wmem) {
int i;
pair< pair< T1, T2> , pair< T3, T4> > * arr;
walloc1d( & arr, N, & mem) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
arr[ i] .first .first = a[ i] ;
arr[ i] .first .second = b[ i] ;
arr[ i] .second .first = c[ i] ;
arr[ i] .second .second = d[ i] ;
}
sort( arr, arr+ N) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
a[ i] = arr[ i] .first .first ;
b[ i] = arr[ i] .first .second ;
c[ i] = arr[ i] .second .first ;
d[ i] = arr[ i] .second .second ;
}
}
template < class T> inline int sort_helper_getbit( T A[ ] ) {
return - 1 ;
}
template <> inline int sort_helper_getbit( int A[ ] ) {
return sizeof ( int ) * 8 ;
}
template <> inline int sort_helper_getbit( unsigned A[ ] ) {
return sizeof ( unsigned ) * 8 ;
}
template <> inline int sort_helper_getbit( long long A[ ] ) {
return sizeof ( long long ) * 8 ;
}
template <> inline int sort_helper_getbit( unsigned long long A[ ] ) {
return sizeof ( unsigned long long ) * 8 ;
}
template <> inline int sort_helper_getbit( char A[ ] ) {
return sizeof ( char ) * 8 ;
}
template < class T> void sortA_1_int_L( int N, T A[ ] , void * mem = wmem) {
int i;
int j;
int k;
int b;
int s;
int ok;
ok = 1 ;
for ( i= ( 1 ) ; i< ( N) ; i++ ) {
if ( A[ i- 1 ] > A[ i] ) {
ok = 0 ;
break ;
}
}
if ( ok) {
return ;
}
if ( N < 128 ) {
sort( A,A+ N) ;
return ;
}
b = sort_helper_getbit( A) ;
if ( b== - 1 ) {
sort( A,A+ N) ;
return ;
}
T mn;
T mx;
mn = mx = A[ 0 ] ;
for ( i= ( 1 ) ; i< ( N) ; i++ ) {
chmin( mn, A[ i] ) ;
}
for ( i= ( 1 ) ; i< ( N) ; i++ ) {
chmax( mx, A[ i] ) ;
}
ok = 1 ;
if ( mn < 0 && mx > 0 && ( mn < - N || mx > N) ) {
ok = 0 ;
}
if ( ok && mx - mn > N) {
ok = 0 ;
}
if ( ok) {
int * tmp;
walloc1d( & tmp, mx- mn+ 1 , & mem) ;
for ( i= ( 0 ) ; i< ( mx- mn+ 1 ) ; i++ ) {
tmp[ i] = 0 ;
}
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
tmp[ A[ i] - mn] ++ ;
}
k = 0 ;
for ( i= ( 0 ) ; i< ( mx- mn+ 1 ) ; i++ ) {
while ( tmp[ i] > 0 ) {
tmp[ i] -- ;
A[ k++ ] = i+ mn;
}
}
return ;
}
{
typename make_unsigned< T> :: type * t[ 2 ] ;
typename make_unsigned< T> :: type mask;
typename make_unsigned< T> :: type cur;
typename make_unsigned< T> :: type one = 1 ;
T tone = 1 ;
int * pos;
int nn = 0 ;
int ss;
s = Ilog2_f_L( N) ;
if ( s > 8 ) {
s = ( 8 + ( s- 7 ) / 2 ) ;
}
ss = 1 ;
for ( ;; ) {
if ( ss >= b) {
break ;
}
if ( mx >= 0 && ( tone << ( ss- 1 ) ) < mx ) {
ss++ ;
continue ;
}
if ( mn < 0 && - ( tone << ( ss- 1 ) ) >= mn ) {
ss++ ;
continue ;
}
break ;
}
k = ( divup_L( ss,s) ) ;
s = ( divup_L( ss,k) ) ;
mask = 0 ;
for ( i= ( 0 ) ; i< ( b) ; i++ ) {
if ( i < s* k) {
mask | = one << i;
}
}
t[ 0 ] = ( typename make_unsigned< T> :: type * ) A;
walloc1d( & t[ 1 ] , N, & mem) ;
walloc1d( & pos, ( 1 << s) + 1 , & mem) ;
for ( j= ( 0 ) ; j< ( k) ; j++ ) {
cur = 0 ;
for ( i= ( 0 ) ; i< ( b) ; i++ ) {
if ( s* j <= i && i < s* ( j+ 1 ) && i < b) {
cur | = one << i;
}
}
for ( i= ( 0 ) ; i< ( ( 1 << s) + 1 ) ; i++ ) {
pos[ i] = 0 ;
}
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
pos[ ( ( t[ nn] [ i] & cur) >> ( s* j) ) + 1 ] ++ ;
}
for ( i= ( 0 ) ; i< ( ( 1 << s) ) ; i++ ) {
pos[ i+ 1 ] + = pos[ i] ;
}
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
t[ nn^ 1 ] [ pos[ ( t[ nn] [ i] & cur) >> ( s* j) ] ++ ] = t[ nn] [ i] ;
}
nn ^ = 1 ;
mask ^ = cur;
}
if ( mn < 0 && mx >= 0 ) {
k = 0 ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
if ( A[ i] < 0 ) {
k++ ;
}
}
for ( i= ( 0 ) ; i< ( k) ; i++ ) {
t[ nn^ 1 ] [ i] = t[ nn] [ N- k+ i] ;
}
for ( i= ( k) ; i< ( N) ; i++ ) {
t[ nn^ 1 ] [ i] = t[ nn] [ i- k] ;
}
nn ^ = 1 ;
}
if ( nn== 1 ) {
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
t[ 0 ] [ i] = t[ 1 ] [ i] ;
}
}
return ;
}
sort( A, A+ N) ;
}
template < class T> void sortA_1_nonint_L( int N, T A[ ] , void * mem = wmem) {
sort( A,A+ N) ;
}
template < class T> void sortA_1_call_L( int N, T A[ ] , void * mem = wmem) {
sortA_1_nonint_L( N, A, mem) ;
}
template <> void sortA_1_call_L( int N, int A[ ] , void * mem) {
sortA_1_int_L( N, A, mem) ;
}
template <> void sortA_1_call_L( int N, unsigned A[ ] , void * mem) {
sortA_1_int_L( N, A, mem) ;
}
template <> void sortA_1_call_L( int N, long long A[ ] , void * mem) {
sortA_1_int_L( N, A, mem) ;
}
template <> void sortA_1_call_L( int N, unsigned long long A[ ] , void * mem) {
sortA_1_int_L( N, A, mem) ;
}
template <> void sortA_1_call_L( int N, char A[ ] , void * mem) {
sortA_1_int_L( N, A, mem) ;
}
template < class T1> void sortA( int N, T1 a[ ] , void * mem = wmem) {
sortA_1_call_L( N, a, mem) ;
}
template < class T1, class T2> void sortA_2_int_L( int N, T1 A[ ] , T2 B[ ] , void * mem = wmem) {
int i;
int b_a;
int b_b;
int s1;
int s2;
int so2;
T1 mn1;
T1 mx1;
T2 mn2;
T2 mx2;
typename cLtraits_try_make_unsigned< T1> :: type r1;
typename cLtraits_try_make_unsigned< T2> :: type r2;
so2 = 1 ;
for ( i= ( 1 ) ; i< ( N) ; i++ ) {
if ( A[ i- 1 ] > A[ i] || ( A[ i- 1 ] == A[ i] && B[ i- 1 ] > B[ i] ) ) {
so2 = 0 ;
break ;
}
}
if ( so2) {
return ;
}
so2 = 1 ;
for ( i= ( 1 ) ; i< ( N) ; i++ ) {
if ( A[ i- 1 ] > A[ i] ) {
so2 = 0 ;
break ;
}
}
if ( so2== 1 ) {
int k = 0 ;
for ( i= ( 1 ) ; i< ( N) ; i++ ) {
if ( A[ i] ! = A[ i- 1 ] ) {
sortA_1_call_L( i- k, B+ k, mem) ;
k = i;
}
}
sortA_1_call_L( N- k, B+ k, mem) ;
return ;
}
if ( N < 128 ) {
sortI( N,A,B,mem) ;
return ;
}
b_a = sort_helper_getbit( A) ;
b_b = sort_helper_getbit( B) ;
if ( b_a == - 1 || b_b == - 1 ) {
sortI( N,A,B,mem) ;
return ;
}
mn1 = mx1 = A[ 0 ] ;
for ( i= ( 1 ) ; i< ( N) ; i++ ) {
chmin( mn1, A[ i] ) ;
}
for ( i= ( 1 ) ; i< ( N) ; i++ ) {
chmax( mx1, A[ i] ) ;
}
mn2 = mx2 = B[ 0 ] ;
for ( i= ( 1 ) ; i< ( N) ; i++ ) {
chmin( mn2, B[ i] ) ;
}
for ( i= ( 1 ) ; i< ( N) ; i++ ) {
chmax( mx2, B[ i] ) ;
}
if ( mn1 < - 4611686016279904256LL || mn2 < - 4611686016279904256LL || mx1 > 4611686016279904256LL || mx2 > 4611686016279904256LL || mx1- mn1 > 4611686016279904256LL || mx2- mn2 > 4611686016279904256LL) {
sortI( N,A,B,mem) ;
return ;
}
r1 = ( typename cLtraits_try_make_unsigned< T1> :: type ) ( mx1) - ( typename cLtraits_try_make_unsigned< T1> :: type ) ( mn1) ;
r2 = ( typename cLtraits_try_make_unsigned< T2> :: type ) ( mx2) - ( typename cLtraits_try_make_unsigned< T2> :: type ) ( mn2) ;
if ( r1 == 0 ) {
sortA_1_call_L( N, B, mem) ;
return ;
}
if ( r2 == 0 ) {
sortA_1_call_L( N, A, mem) ;
return ;
}
if ( r1 <= N) {
so2 = 1 ;
for ( i= ( 1 ) ; i< ( N) ; i++ ) {
if ( B[ i- 1 ] > B[ i] ) {
so2 = 0 ;
break ;
}
}
if ( so2 == 1 ) {
T1* aa;
T2* bb;
int * pos;
int k;
walloc1d( & aa,N,& mem) ;
walloc1d( & bb,N,& mem) ;
walloc1d( & pos,r1+ 2 ,& mem) ;
for ( i= ( 0 ) ; i< ( r1+ 2 ) ; i++ ) {
pos[ i] = 0 ;
}
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
aa[ i] = A[ i] ;
}
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
bb[ i] = B[ i] ;
}
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
pos[ ( typename cLtraits_try_make_unsigned< T1> :: type ) ( ( typename cLtraits_try_make_unsigned< T1> :: type ) aa[ i] - ( typename cLtraits_try_make_unsigned< T1> :: type ) mn1) + 1 ] ++ ;
}
for ( i= ( 1 ) ; i< ( r1+ 2 ) ; i++ ) {
pos[ i] + = pos[ i- 1 ] ;
}
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
k = pos[ ( typename cLtraits_try_make_unsigned< T1> :: type ) ( ( typename cLtraits_try_make_unsigned< T1> :: type ) aa[ i] - ( typename cLtraits_try_make_unsigned< T1> :: type ) mn1) + 0 ] ++ ;
A[ k] = aa[ i] ;
B[ k] = bb[ i] ;
}
return ;
}
}
s1 = s2 = 1 ;
while ( s1 < 64 && r1 >= ( 1ULL<< s1) ) {
s1++ ;
}
while ( s2 < 64 && r2 >= ( 1ULL<< s2) ) {
s2++ ;
}
if ( s1 + s2 <= 32 ) {
unsigned * tmp;
walloc1d( & tmp,N,& mem) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
tmp[ i] = ( ( ( unsigned ) ( ( int ) A[ i] - ( int ) mn1) ) << s2) | ( ( unsigned ) ( ( int ) B[ i] - ( int ) mn2) ) ;
}
sortA_1_call_L( N, tmp, mem) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
A[ i] = ( ( int ) ( tmp[ i] >> s2) ) + ( ( int ) mn1) ;
B[ i] = ( ( int ) ( tmp[ i] & ( ( 1U<< s2) - 1 ) ) ) + ( ( int ) mn2) ;
}
return ;
}
if ( s1 + s2 <= 64 ) {
unsigned long long * tmp;
walloc1d( & tmp,N,& mem) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
tmp[ i] = ( ( ( unsigned long long ) ( ( long long ) A[ i] - ( long long ) mn1) ) << s2) | ( ( unsigned long long ) ( ( long long ) B[ i] - ( long long ) mn2) ) ;
}
sortA_1_call_L( N, tmp, mem) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
A[ i] = ( ( long long ) ( tmp[ i] >> s2) ) + ( ( long long ) mn1) ;
B[ i] = ( ( long long ) ( tmp[ i] & ( ( 1ULL<< s2) - 1 ) ) ) + ( ( long long ) mn2) ;
}
return ;
}
sortI( N,A,B,mem) ;
}
template < class T1, class T2> void sortA_2_nonint_L( int N, T1 A[ ] , T2 B[ ] , void * mem = wmem) {
sortI( N,A,B,mem) ;
}
template < class T1, class T2> void sortA_2_call_L( int N, T1 A[ ] , T2 B[ ] , void * mem = wmem) {
sortA_2_nonint_L( N, A, B, mem) ;
}
template < class T2> void sortA_2_call_L( int N, int A[ ] , T2 B[ ] , void * mem) {
sortA_2_int_L( N, A, B, mem) ;
}
template < class T2> void sortA_2_call_L( int N, unsigned A[ ] , T2 B[ ] , void * mem) {
sortA_2_int_L( N, A, B, mem) ;
}
template < class T2> void sortA_2_call_L( int N, long long A[ ] , T2 B[ ] , void * mem) {
sortA_2_int_L( N, A, B, mem) ;
}
template < class T2> void sortA_2_call_L( int N, unsigned long long A[ ] , T2 B[ ] , void * mem) {
sortA_2_int_L( N, A, B, mem) ;
}
template < class T2> void sortA_2_call_L( int N, char A[ ] , T2 B[ ] , void * mem) {
sortA_2_int_L( N, A, B, mem) ;
}
template < class T1, class T2> void sortA( int N, T1 a[ ] , T2 b[ ] , void * mem = wmem) {
sortA_2_call_L( N, a, b, mem) ;
}
template < class T1, class T2, class T3> void sortA( int N, T1 a[ ] , T2 b[ ] , T3 c[ ] , void * mem = wmem) {
int i;
pair< T1, pair< T2, T3> > * arr;
walloc1d( & arr, N, & mem) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
arr[ i] .first = a[ i] ;
arr[ i] .second .first = b[ i] ;
arr[ i] .second .second = c[ i] ;
}
sort( arr, arr+ N) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
a[ i] = arr[ i] .first ;
b[ i] = arr[ i] .second .first ;
c[ i] = arr[ i] .second .second ;
}
}
template < class T1, class T2, class T3, class T4> void sortA( int N, T1 a[ ] , T2 b[ ] , T3 c[ ] , T4 d[ ] , void * mem = wmem) {
int i;
pair< pair< T1, T2> , pair< T3, T4> > * arr;
walloc1d( & arr, N, & mem) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
arr[ i] .first .first = a[ i] ;
arr[ i] .first .second = b[ i] ;
arr[ i] .second .first = c[ i] ;
arr[ i] .second .second = d[ i] ;
}
sort( arr, arr+ N) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
a[ i] = arr[ i] .first .first ;
b[ i] = arr[ i] .first .second ;
c[ i] = arr[ i] .second .first ;
d[ i] = arr[ i] .second .second ;
}
}
template < class T1, class T2> void sortA_index( int N, T1 a[ ] , T2 b[ ] , void * mem = wmem) {
int i;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
b[ i] = i;
}
sortA( N,a,b,mem) ;
}
template < class T1, class T2, class T3> void sortA_index( int N, T1 a[ ] , T2 b[ ] , T3 c[ ] , void * mem = wmem) {
int i;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
c[ i] = i;
}
sortA( N,a,b,c,mem) ;
}
template < class T1, class T2, class T3, class T4> void sortA_index( int N, T1 a[ ] , T2 b[ ] , T3 c[ ] , T4 d[ ] , void * mem = wmem) {
int i;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
d[ i] = i;
}
sortA( N,a,b,c,d,mem) ;
}
template < class T> struct segtree_Point_Maxval{
int N;
int logN;
T* mx;
void malloc ( int maxN, int once = 0 ) {
int i;
for ( i= 1 ; i< maxN; i* = 2 ) {
;
}
mx = new T[ 2 * i] ;
if ( once) {
setN( maxN) ;
}
}
void walloc( int maxN, int once = 0 , void ** mem = & wmem) {
int i;
for ( i= 1 ; i< maxN; i* = 2 ) {
;
}
walloc1d( & mx, 2 * i, mem) ;
if ( once) {
setN( maxN) ;
}
}
void free ( void ) {
delete [ ] mx;
}
T& operator[ ] ( int i) {
return mx[ N+ i] ;
}
void setN( int n, int zerofill = 1 , int dobuild = 1 ) {
int i;
for ( i= 1 ,logN= 0 ; i< n; i* = 2 ,logN++ ) {
;
}
N = i;
if ( zerofill) {
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
mx[ N+ i] = 0 ;
}
}
if ( dobuild) {
build( ) ;
}
}
void build( void ) {
int i;
for ( i= N- 1 ; i; i-- ) {
mx[ i] = max_L( mx[ 2 * i] , mx[ 2 * i+ 1 ] ) ;
}
}
inline void build( int a) {
while ( a > 1 ) {
a / = 2 ;
mx[ a] = max_L( mx[ 2 * a] , mx[ 2 * a+ 1 ] ) ;
}
}
inline void change( int a, T val) {
mx[ a+ N] = val;
build( a+ N) ;
}
inline void add( int a, T val) {
mx[ a+ N] + = val;
build( a+ N) ;
}
inline T getMaxVal( int a, int b) {
T res;
T tmp;
int fga = 0 ;
int fgb = 0 ;
a + = N;
b + = N;
while ( a < b) {
if ( a% 2 ) {
if ( fga) {
res = max_L( res, mx[ a] ) ;
}
else {
res = mx[ a] ;
fga = 1 ;
}
a++ ;
}
if ( b% 2 ) {
b-- ;
if ( fgb) {
tmp = max_L( mx[ b] , tmp) ;
}
else {
tmp = mx[ b] ;
fgb = 1 ;
}
}
a / = 2 ;
b / = 2 ;
}
if ( fga== 1 && fgb== 0 ) {
return res;
}
if ( fga== 0 && fgb== 1 ) {
return tmp;
}
if ( fga== 1 && fgb== 1 ) {
res = max_L( res, tmp) ;
return res;
}
return res;
}
}
;
template < class T, class S> inline int vec2arr( vector< T> & v, S arr[ ] ) {
int i;
int N = v.size ( ) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
arr[ i] = v[ i] ;
}
return N;
}
template < class T, class S1, class S2> inline int vec2arr( vector< vector< T>> & v, S1 arr1[ ] , S2 arr2[ ] ) {
int i;
int N = v.size ( ) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
arr1[ i] = v[ i] [ 0 ] ;
arr2[ i] = v[ i] [ 1 ] ;
}
return N;
}
template < class T, class S1, class S2, class S3> inline int vec2arr( vector< vector< T>> & v, S1 arr1[ ] , S2 arr2[ ] , S3 arr3[ ] ) {
int i;
int N = v.size ( ) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
arr1[ i] = v[ i] [ 0 ] ;
arr2[ i] = v[ i] [ 1 ] ;
arr3[ i] = v[ i] [ 2 ] ;
}
return N;
}
#define main dummy_main
int main( ) {
wmem = memarr;
return 0 ;
}
#undef main
class Solution{
public :
long long maxBalancedSubsequenceSum( vector< int > & nums) {
int i;
dummy_main( ) ;
static int N;
static int A[ 100000 ] ;
static int ind[ 100000 ] ;
segtree_Point_Maxval< long long > t;
long long res = 0 ;
long long tmp;
N = vec2arr( nums, A) ;
int Nzj9Y0kE;
cLtraits_try_make_signed< remove_reference< decltype( ( * ( ( int * ) NULL ) ) ) > :: type > :: type bkxOPzPX;
if ( N== 0 ) {
bkxOPzPX = 0 ;
}
else {
bkxOPzPX = A[ 0 ] ;
for ( Nzj9Y0kE= ( 1 ) ; Nzj9Y0kE< ( N) ; Nzj9Y0kE++ ) {
bkxOPzPX = max_L( bkxOPzPX, A[ Nzj9Y0kE] ) ;
}
}
tmp = bkxOPzPX;
if ( tmp <= 0 ) {
return tmp;
}
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
A[ i] - = i;
}
sortA_index( N, A, ind) ;
t.walloc ( N, 1 ) ;
for ( i= ( 0 ) ; i< ( N) ; i++ ) {
if ( ind[ i] > 0 ) {
chmax( res, tmp = t.getMaxVal ( 0 , ind[ i] ) + A[ i] + ind[ i] ) ;
}
else {
chmax( res, tmp = 0 + A[ i] + ind[ i] ) ;
}
if ( tmp > 0 ) {
t.change ( ind[ i] , tmp) ;
}
}
return res;
}
}
;
// cLay version 20231031-1
// --- original code ---
// #define main dummy_main
// {}
// #undef main
//
// class Solution {
// public:
// ll maxBalancedSubsequenceSum(VI &nums) {
// dummy_main();
// static int N, A[1d5], ind[];
// segtree_Point_Maxval<ll> t;
// ll res = 0, tmp;
//
// N = vec2arr(nums, A);
// tmp = max(A(N));
// if(tmp <= 0) return tmp;
//
// rep(i,N) A[i] -= i;
// sortA_index(N, A, ind);
// t.walloc(N, 1);
//
// rep(i,N){
// res >?= tmp = if[ind[i]>0, t.getMaxVal(0, ind[i]), 0] + A[i] + ind[i];
// if(tmp > 0) t.change(ind[i], tmp);
// }
//
// return res;
// }
// };
#pragma GCC optimize("Ofast")
#pragma GCC optimize("unroll-loops")
#pragma GCC optimize("inline")
#include<bits/stdc++.h>
using namespace std;
template<class T> struct cLtraits_identity{
  using type = T;
}
;
template<class T> using cLtraits_try_make_signed =
  typename conditional<
    is_integral<T>::value,
    make_signed<T>,
    cLtraits_identity<T>
    >::type;
template<class T> using cLtraits_try_make_unsigned =
  typename conditional<
    is_integral<T>::value,
    make_unsigned<T>,
    cLtraits_identity<T>
    >::type;
template <class S, class T> struct cLtraits_common_type{
  using tS = typename cLtraits_try_make_signed<S>::type;
  using tT = typename cLtraits_try_make_signed<T>::type;
  using type = typename common_type<tS,tT>::type;
}
;
void*wmem;
char memarr[96000000];
template<class S, class T> inline auto max_L(S a, T b)
-> typename cLtraits_common_type<S,T>::type{
  return (typename cLtraits_common_type<S,T>::type) a >= (typename cLtraits_common_type<S,T>::type) b ? a : b;
}
template<class S, class T> inline S chmin(S &a, T b){
  if(a>b){
    a=b;
  }
  return a;
}
template<class S, class T> inline S chmax(S &a, T b){
  if(a<b){
    a=b;
  }
  return a;
}
template<class S, class T> inline S divup_L(S a, T b){
  return (a+b-1)/b;
}
template<class T> inline void walloc1d(T **arr, int x, void **mem = &wmem){
  static int skip[16] = {0, 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
  (*mem) = (void*)( ((char*)(*mem)) + skip[((unsigned long long)(*mem)) & 15] );
  (*arr)=(T*)(*mem);
  (*mem)=((*arr)+x);
}
template<class T> inline void walloc1d(T **arr, int x1, int x2, void **mem = &wmem){
  walloc1d(arr, x2-x1, mem);
  (*arr) -= x1;
}
inline int Ilog2_f_L(const int n){
  int res;
  if(n <= 0){
    return -1;
  }
  res = sizeof(int) * 8 - __builtin_clz(n) - 1;
  return res;
}
inline int Ilog2_f_L(const long long n){
  int res;
  if(n <= 0){
    return -1;
  }
  res = sizeof(long long) * 8 - __builtin_clzll(n) - 1;
  return res;
}
template<class T1> void sortI(int N, T1 a[], void *mem = wmem){
  sort(a, a+N);
}
template<class T1, class T2> void sortI(int N, T1 a[], T2 b[], void *mem = wmem){
  int i;
  pair<T1, T2>*arr;
  walloc1d(&arr, N, &mem);
  for(i=(0);i<(N);i++){
    arr[i].first = a[i];
    arr[i].second = b[i];
  }
  sort(arr, arr+N);
  for(i=(0);i<(N);i++){
    a[i] = arr[i].first;
    b[i] = arr[i].second;
  }
}
template<class T1, class T2, class T3> void sortI(int N, T1 a[], T2 b[], T3 c[], void *mem = wmem){
  int i;
  pair<T1, pair<T2, T3> >*arr;
  walloc1d(&arr, N, &mem);
  for(i=(0);i<(N);i++){
    arr[i].first = a[i];
    arr[i].second.first = b[i];
    arr[i].second.second = c[i];
  }
  sort(arr, arr+N);
  for(i=(0);i<(N);i++){
    a[i] = arr[i].first;
    b[i] = arr[i].second.first;
    c[i] = arr[i].second.second;
  }
}
template<class T1, class T2, class T3, class T4> void sortI(int N, T1 a[], T2 b[], T3 c[], T4 d[], void *mem = wmem){
  int i;
  pair<pair<T1, T2>, pair<T3, T4> >*arr;
  walloc1d(&arr, N, &mem);
  for(i=(0);i<(N);i++){
    arr[i].first.first = a[i];
    arr[i].first.second = b[i];
    arr[i].second.first = c[i];
    arr[i].second.second = d[i];
  }
  sort(arr, arr+N);
  for(i=(0);i<(N);i++){
    a[i] = arr[i].first.first;
    b[i] = arr[i].first.second;
    c[i] = arr[i].second.first;
    d[i] = arr[i].second.second;
  }
}
template<class T> inline int sort_helper_getbit(T A[]){
  return -1;
}
template<> inline int sort_helper_getbit(int A[]){
  return sizeof(int)*8;
}
template<> inline int sort_helper_getbit(unsigned A[]){
  return sizeof(unsigned)*8;
}
template<> inline int sort_helper_getbit(long long A[]){
  return sizeof(long long)*8;
}
template<> inline int sort_helper_getbit(unsigned long long A[]){
  return sizeof(unsigned long long)*8;
}
template<> inline int sort_helper_getbit(char A[]){
  return sizeof(char)*8;
}
template<class T> void sortA_1_int_L(int N, T A[], void *mem = wmem){
  int i;
  int j;
  int k;
  int b;
  int s;
  int ok;
  ok = 1;
  for(i=(1);i<(N);i++){
    if(A[i-1] > A[i]){
      ok = 0;
      break;
    }
  }
  if(ok){
    return;
  }
  if(N < 128){
    sort(A,A+N);
    return;
  }
  b = sort_helper_getbit(A);
  if(b==-1){
    sort(A,A+N);
    return;
  }
  T mn;
  T mx;
  mn = mx = A[0];
  for(i=(1);i<(N);i++){
    chmin(mn, A[i]);
  }
  for(i=(1);i<(N);i++){
    chmax(mx, A[i]);
  }
  ok = 1;
  if(mn < 0 && mx > 0 && (mn < -N || mx > N)){
    ok = 0;
  }
  if(ok && mx - mn > N){
    ok = 0;
  }
  if(ok){
    int*tmp;
    walloc1d(&tmp, mx-mn+1, &mem);
    for(i=(0);i<(mx-mn+1);i++){
      tmp[i] = 0;
    }
    for(i=(0);i<(N);i++){
      tmp[A[i]-mn]++;
    }
    k = 0;
    for(i=(0);i<(mx-mn+1);i++){
      while(tmp[i] > 0){
        tmp[i]--;
        A[k++] = i+mn;
      }
    }
    return;
  }
  {
    typename make_unsigned<T>::type *t[2];
    typename make_unsigned<T>::type  mask;
    typename make_unsigned<T>::type  cur;
    typename make_unsigned<T>::type  one = 1;
    T tone = 1;
    int*pos;
    int nn = 0;
    int ss;
    s =Ilog2_f_L(N);
    if(s > 8){
      s = (8 + (s-7)/2);
    }
    ss = 1;
    for(;;){
      if(ss >= b){
        break;
      }
      if( mx >= 0 && (tone << (ss-1)) < mx ){
        ss++;
        continue;
      }
      if( mn < 0 && -(tone << (ss-1)) >= mn ){
        ss++;
        continue;
      }
      break;
    }
    k =(divup_L(ss,s));
    s =(divup_L(ss,k));
    mask = 0;
    for(i=(0);i<(b);i++){
      if(i < s*k){
        mask |= one << i;
      }
    }
    t[0] = (typename make_unsigned<T>::type *) A;
    walloc1d(&t[1], N, &mem);
    walloc1d(&pos, (1<<s)+1, &mem);
    for(j=(0);j<(k);j++){
      cur = 0;
      for(i=(0);i<(b);i++){
        if(s*j <= i && i < s*(j+1) && i < b){
          cur |= one << i;
        }
      }
      for(i=(0);i<((1<<s)+1);i++){
        pos[i] = 0;
      }
      for(i=(0);i<(N);i++){
        pos[((t[nn][i]&cur)>>(s*j))+1]++;
      }
      for(i=(0);i<((1<<s));i++){
        pos[i+1] += pos[i];
      }
      for(i=(0);i<(N);i++){
        t[nn^1][pos[(t[nn][i]&cur)>>(s*j)]++] = t[nn][i];
      }
      nn ^= 1;
      mask ^= cur;
    }
    if(mn < 0 && mx >= 0){
      k = 0;
      for(i=(0);i<(N);i++){
        if(A[i] < 0){
          k++;
        }
      }
      for(i=(0);i<(k);i++){
        t[nn^1][i] = t[nn][N-k+i];
      }
      for(i=(k);i<(N);i++){
        t[nn^1][i] = t[nn][i-k];
      }
      nn ^= 1;
    }
    if(nn==1){
      for(i=(0);i<(N);i++){
        t[0][i] = t[1][i];
      }
    }
    return;
  }
  sort(A, A+N);
}
template<class T> void sortA_1_nonint_L(int N, T A[], void *mem = wmem){
  sort(A,A+N);
}
template<class T> void sortA_1_call_L(int N, T A[], void *mem = wmem){
  sortA_1_nonint_L(N, A, mem);
}
template<> void sortA_1_call_L(int N, int A[], void *mem){
  sortA_1_int_L(N, A, mem);
}
template<> void sortA_1_call_L(int N, unsigned A[], void *mem){
  sortA_1_int_L(N, A, mem);
}
template<> void sortA_1_call_L(int N, long long A[], void *mem){
  sortA_1_int_L(N, A, mem);
}
template<> void sortA_1_call_L(int N, unsigned long long A[], void *mem){
  sortA_1_int_L(N, A, mem);
}
template<> void sortA_1_call_L(int N, char A[], void *mem){
  sortA_1_int_L(N, A, mem);
}
template<class T1> void sortA(int N, T1 a[], void *mem = wmem){
  sortA_1_call_L(N, a, mem);
}
template<class T1, class T2> void sortA_2_int_L(int N, T1 A[], T2 B[], void *mem = wmem){
  int i;
  int b_a;
  int b_b;
  int s1;
  int s2;
  int so2;
  T1 mn1;
  T1 mx1;
  T2 mn2;
  T2 mx2;
  typename cLtraits_try_make_unsigned<T1>::type r1;
  typename cLtraits_try_make_unsigned<T2>::type r2;
  so2 = 1;
  for(i=(1);i<(N);i++){
    if(A[i-1] > A[i] || (A[i-1]==A[i] && B[i-1] > B[i])){
      so2 = 0;
      break;
    }
  }
  if(so2){
    return;
  }
  so2 = 1;
  for(i=(1);i<(N);i++){
    if(A[i-1] > A[i]){
      so2 = 0;
      break;
    }
  }
  if(so2==1){
    int k = 0;
    for(i=(1);i<(N);i++){
      if(A[i] != A[i-1]){
        sortA_1_call_L(i-k, B+k, mem);
        k = i;
      }
    }
    sortA_1_call_L(N-k, B+k, mem);
    return;
  }
  if(N < 128){
    sortI(N,A,B,mem);
    return;
  }
  b_a = sort_helper_getbit(A);
  b_b = sort_helper_getbit(B);
  if(b_a == -1 || b_b == -1){
    sortI(N,A,B,mem);
    return;
  }
  mn1 = mx1 = A[0];
  for(i=(1);i<(N);i++){
    chmin(mn1, A[i]);
  }
  for(i=(1);i<(N);i++){
    chmax(mx1, A[i]);
  }
  mn2 = mx2 = B[0];
  for(i=(1);i<(N);i++){
    chmin(mn2, B[i]);
  }
  for(i=(1);i<(N);i++){
    chmax(mx2, B[i]);
  }
  if(mn1 < -4611686016279904256LL || mn2 < -4611686016279904256LL || mx1 > 4611686016279904256LL || mx2 > 4611686016279904256LL || mx1-mn1 > 4611686016279904256LL || mx2-mn2 > 4611686016279904256LL){
    sortI(N,A,B,mem);
    return;
  }
  r1 = (typename cLtraits_try_make_unsigned<T1>::type)(mx1) - (typename cLtraits_try_make_unsigned<T1>::type)(mn1);
  r2 = (typename cLtraits_try_make_unsigned<T2>::type)(mx2) - (typename cLtraits_try_make_unsigned<T2>::type)(mn2);
  if(r1 == 0){
    sortA_1_call_L(N, B, mem);
    return;
  }
  if(r2 == 0){
    sortA_1_call_L(N, A, mem);
    return;
  }
  if(r1 <= N){
    so2 = 1;
    for(i=(1);i<(N);i++){
      if(B[i-1] > B[i]){
        so2 = 0;
        break;
      }
    }
    if(so2 == 1){
      T1*aa;
      T2*bb;
      int*pos;
      int k;
      walloc1d(&aa,N,&mem);
      walloc1d(&bb,N,&mem);
      walloc1d(&pos,r1+2,&mem);
      for(i=(0);i<(r1+2);i++){
        pos[i] = 0;
      }
      for(i=(0);i<(N);i++){
        aa[i] = A[i];
      }
      for(i=(0);i<(N);i++){
        bb[i] = B[i];
      }
      for(i=(0);i<(N);i++){
        pos[(typename cLtraits_try_make_unsigned<T1>::type)((typename cLtraits_try_make_unsigned<T1>::type)aa[i]-(typename cLtraits_try_make_unsigned<T1>::type)mn1)+1]++;
      }
      for(i=(1);i<(r1+2);i++){
        pos[i] += pos[i-1];
      }
      for(i=(0);i<(N);i++){
        k = pos[(typename cLtraits_try_make_unsigned<T1>::type)((typename cLtraits_try_make_unsigned<T1>::type)aa[i]-(typename cLtraits_try_make_unsigned<T1>::type)mn1)+0]++;
        A[k] = aa[i];
        B[k] = bb[i];
      }
      return;
    }
  }
  s1 = s2 = 1;
  while( s1 < 64 && r1 >= (1ULL<<s1) ){
    s1++;
  }
  while( s2 < 64 && r2 >= (1ULL<<s2) ){
    s2++;
  }
  if(s1 + s2 <= 32){
    unsigned*tmp;
    walloc1d(&tmp,N,&mem);
    for(i=(0);i<(N);i++){
      tmp[i] = (((unsigned)((int)A[i]-(int)mn1)) << s2) | ((unsigned)((int)B[i]-(int)mn2));
    }
    sortA_1_call_L(N, tmp, mem);
    for(i=(0);i<(N);i++){
      A[i] = ((int)(tmp[i] >> s2)) + ((int)mn1);
      B[i] = ((int)(tmp[i] & ((1U<<s2)-1))) + ((int)mn2);
    }
    return;
  }
  if(s1 + s2 <= 64){
    unsigned long long*tmp;
    walloc1d(&tmp,N,&mem);
    for(i=(0);i<(N);i++){
      tmp[i] = (((unsigned long long)((long long)A[i]-(long long)mn1)) << s2) | ((unsigned long long)((long long)B[i]-(long long)mn2));
    }
    sortA_1_call_L(N, tmp, mem);
    for(i=(0);i<(N);i++){
      A[i] = ((long long)(tmp[i] >> s2)) + ((long long)mn1);
      B[i] = ((long long)(tmp[i] & ((1ULL<<s2)-1))) + ((long long)mn2);
    }
    return;
  }
  sortI(N,A,B,mem);
}
template<class T1, class T2> void sortA_2_nonint_L(int N, T1 A[], T2 B[], void *mem = wmem){
  sortI(N,A,B,mem);
}
template<class T1, class T2> void sortA_2_call_L(int N, T1 A[], T2 B[], void *mem = wmem){
  sortA_2_nonint_L(N, A, B, mem);
}
template<class T2> void sortA_2_call_L(int N, int A[], T2 B[], void *mem){
  sortA_2_int_L(N, A, B, mem);
}
template<class T2> void sortA_2_call_L(int N, unsigned A[], T2 B[], void *mem){
  sortA_2_int_L(N, A, B, mem);
}
template<class T2> void sortA_2_call_L(int N, long long A[], T2 B[], void *mem){
  sortA_2_int_L(N, A, B, mem);
}
template<class T2> void sortA_2_call_L(int N, unsigned long long A[], T2 B[], void *mem){
  sortA_2_int_L(N, A, B, mem);
}
template<class T2> void sortA_2_call_L(int N, char A[], T2 B[], void *mem){
  sortA_2_int_L(N, A, B, mem);
}
template<class T1, class T2> void sortA(int N, T1 a[], T2 b[], void *mem = wmem){
  sortA_2_call_L(N, a, b, mem);
}
template<class T1, class T2, class T3> void sortA(int N, T1 a[], T2 b[], T3 c[], void *mem = wmem){
  int i;
  pair<T1, pair<T2, T3> >*arr;
  walloc1d(&arr, N, &mem);
  for(i=(0);i<(N);i++){
    arr[i].first = a[i];
    arr[i].second.first = b[i];
    arr[i].second.second = c[i];
  }
  sort(arr, arr+N);
  for(i=(0);i<(N);i++){
    a[i] = arr[i].first;
    b[i] = arr[i].second.first;
    c[i] = arr[i].second.second;
  }
}
template<class T1, class T2, class T3, class T4> void sortA(int N, T1 a[], T2 b[], T3 c[], T4 d[], void *mem = wmem){
  int i;
  pair<pair<T1, T2>, pair<T3, T4> >*arr;
  walloc1d(&arr, N, &mem);
  for(i=(0);i<(N);i++){
    arr[i].first.first = a[i];
    arr[i].first.second = b[i];
    arr[i].second.first = c[i];
    arr[i].second.second = d[i];
  }
  sort(arr, arr+N);
  for(i=(0);i<(N);i++){
    a[i] = arr[i].first.first;
    b[i] = arr[i].first.second;
    c[i] = arr[i].second.first;
    d[i] = arr[i].second.second;
  }
}
template<class T1, class T2> void sortA_index(int N, T1 a[], T2 b[], void *mem = wmem){
  int i;
  for(i=(0);i<(N);i++){
    b[i] = i;
  }
  sortA(N,a,b,mem);
}
template<class T1, class T2, class T3> void sortA_index(int N, T1 a[], T2 b[], T3 c[], void *mem = wmem){
  int i;
  for(i=(0);i<(N);i++){
    c[i] = i;
  }
  sortA(N,a,b,c,mem);
}
template<class T1, class T2, class T3, class T4> void sortA_index(int N, T1 a[], T2 b[], T3 c[], T4 d[], void *mem = wmem){
  int i;
  for(i=(0);i<(N);i++){
    d[i] = i;
  }
  sortA(N,a,b,c,d,mem);
}
template<class T> struct segtree_Point_Maxval{
  int N;
  int logN;
  T*mx;
  void malloc(int maxN, int once = 0){
    int i;
    for(i=1;i<maxN;i*=2){
      ;
    }
    mx = new T[2*i];
    if(once){
      setN(maxN);
    }
  }
  void walloc(int maxN, int once = 0, void **mem = &wmem){
    int i;
    for(i=1;i<maxN;i*=2){
      ;
    }
    walloc1d(&mx, 2*i, mem);
    if(once){
      setN(maxN);
    }
  }
  void free(void){
    delete [] mx;
  }
  T& operator[](int i){
    return mx[N+i];
  }
  void setN(int n, int zerofill = 1, int dobuild = 1){
    int i;
    for(i=1,logN=0;i<n;i*=2,logN++){
      ;
    }
    N = i;
    if(zerofill){
      for(i=(0);i<(N);i++){
        mx[N+i] = 0;
      }
    }
    if(dobuild){
      build();
    }
  }
  void build(void){
    int i;
    for(i=N-1;i;i--){
      mx[i] =max_L(mx[2*i], mx[2*i+1]);
    }
  }
  inline void build(int a){
    while(a > 1){
      a /= 2;
      mx[a] =max_L(mx[2*a], mx[2*a+1]);
    }
  }
  inline void change(int a, T val){
    mx[a+N] = val;
    build(a+N);
  }
  inline void add(int a, T val){
    mx[a+N] += val;
    build(a+N);
  }
  inline T getMaxVal(int a, int b){
    T res;
    T tmp;
    int fga = 0;
    int fgb = 0;
    a += N;
    b += N;
    while(a < b){
      if(a%2){
        if(fga){
          res =max_L(res, mx[a]);
        }
        else{
          res = mx[a];
          fga = 1;
        }
        a++;
      }
      if(b%2){
        b--;
        if(fgb){
          tmp =max_L(mx[b], tmp);
        }
        else{
          tmp = mx[b];
          fgb = 1;
        }
      }
      a /= 2;
      b /= 2;
    }
    if(fga==1 && fgb==0){
      return res;
    }
    if(fga==0 && fgb==1){
      return tmp;
    }
    if(fga==1 && fgb==1){
      res =max_L(res, tmp);
      return res;
    }
    return res;
  }
}
;
template<class T, class S> inline int vec2arr(vector<T> &v, S arr[]){
  int i;
  int N = v.size();
  for(i=(0);i<(N);i++){
    arr[i] = v[i];
  }
  return N;
}
template<class T, class S1, class S2> inline int vec2arr(vector<vector<T>> &v, S1 arr1[], S2 arr2[]){
  int i;
  int N = v.size();
  for(i=(0);i<(N);i++){
    arr1[i] = v[i][0];
    arr2[i] = v[i][1];
  }
  return N;
}
template<class T, class S1, class S2, class S3> inline int vec2arr(vector<vector<T>> &v, S1 arr1[], S2 arr2[], S3 arr3[]){
  int i;
  int N = v.size();
  for(i=(0);i<(N);i++){
    arr1[i] = v[i][0];
    arr2[i] = v[i][1];
    arr3[i] = v[i][2];
  }
  return N;
}
#define main dummy_main
int main(){
  wmem = memarr;
  return 0;
}
#undef main
class Solution{
  public:
  long long maxBalancedSubsequenceSum(vector<int> &nums){
    int i;
    dummy_main();
    static int N;
    static int A[100000];
    static int ind[100000];
    segtree_Point_Maxval<long long> t;
    long long res = 0;
    long long tmp;
    N = vec2arr(nums, A);
    int Nzj9Y0kE;
    cLtraits_try_make_signed<remove_reference<decltype((*((int*)NULL)))>::type>::type bkxOPzPX;
    if(N==0){
      bkxOPzPX = 0;
    }
    else{
      bkxOPzPX = A[0];
      for(Nzj9Y0kE=(1);Nzj9Y0kE<(N);Nzj9Y0kE++){
        bkxOPzPX = max_L(bkxOPzPX, A[Nzj9Y0kE]);
      }
    }
    tmp =bkxOPzPX;
    if(tmp <= 0){
      return tmp;
    }
    for(i=(0);i<(N);i++){
      A[i] -= i;
    }
    sortA_index(N, A, ind);
    t.walloc(N, 1);
    for(i=(0);i<(N);i++){
      if(ind[i]>0){
        chmax(res, tmp =t.getMaxVal(0, ind[i])+ A[i] + ind[i]);
      }
      else{
        chmax(res, tmp =0+ A[i] + ind[i]);
      }
      if(tmp > 0){
        t.change(ind[i], tmp);
      }
    }
    return res;
  }
}
;
// cLay version 20231031-1

// --- original code ---
// #define main dummy_main
// {}
// #undef main
// 
// class Solution {
// public:
//   ll maxBalancedSubsequenceSum(VI &nums) {
//     dummy_main();
//     static int N, A[1d5], ind[];
//     segtree_Point_Maxval<ll> t;
//     ll res = 0, tmp;
// 
//     N = vec2arr(nums, A);
//     tmp = max(A(N));
//     if(tmp <= 0) return tmp;
// 
//     rep(i,N) A[i] -= i;
//     sortA_index(N, A, ind);
//     t.walloc(N, 1);
// 
//     rep(i,N){
//       res >?= tmp = if[ind[i]>0, t.getMaxVal(0, ind[i]), 0] + A[i] + ind[i];
//       if(tmp > 0) t.change(ind[i], tmp);
//     }
// 
//     return res;
//   }
// };
