#if loc||local #define _GLIBCXX_DEBUG #endif #include using namespace std; #define rep(i,n) for(ll i=0;i<(n);++i) using ll = int_fast64_t; using pll = pair; constexpr ll INF = 1LL<<60; constexpr ll MOD = 1e9+7; template bool chmax(T &a,const T &b){if(a bool chmin(T &a,const T &b){if(a>b){a=b;return 1;}return 0;} #if loc||local templatevoid dump(T&& t){cerr< void dump(T&& h, Ts&&... t){cerr<(t)...);} #else void dump(){} template void dump(T&& h, Ts&&... t){} #endif template istream &operator>>(istream&is,vector&v){for(auto &elemnt:v)is>>elemnt;return is;} template istream &operator>>(istream&is,pair&p){is>>p.first>>p.second;return is;} template ostream &operator<<(ostream& os,vectorconst& v){for(auto const& vi:v)os< ostream &operator<<(ostream& os,pairconst& p){os<vector vec(size_t a){return vector(a);} templateauto vec(size_t a, Ts... ts){return vector(ts...))>(a, vec(ts...));} ll LIS(const vector& v){ ll n=((ll)v.size()); constexpr ll INF = (1LL<<60); vector lis(n+1,INF); lis[0]=-INF; for(ll i=0;i>n; vector a(n); cin>>a; vector lef_inc(n),rig_inc(n); vector lef_dec(n),rig_dec(n); { vector lis(n+1,INF); lis[0] = 0; ll len = 0; for(int i=0;i(val,a[i]); if(lis[len+1]!=INF){ len++; } lef_inc[i] = len; } dump(lef_inc); } { vector lis(n+1,INF); lis[0] = 0; reverse(begin(a),end(a)); ll len = 0; for(int i=0;i(val,a[i]); if(lis[len+1]!=INF){ len++; } rig_inc[i] = len; } reverse(begin(rig_inc),end(rig_inc)); reverse(begin(a),end(a)); dump(rig_inc); } { vector lis(n+1,-INF); lis[0] = INF; ll len = 0; for(int i=0;i()); ll val = *itr; *itr = max(val,a[i]); if(lis[len+1]!=-INF)len++; lef_dec[i] = len; } dump(lef_dec); } { vector lis(n+1,-INF); lis[0] = INF; ll len = 0; reverse(begin(a),end(a)); for(int i=0;i()); ll val = *itr; *itr = max(val,a[i]); if(lis[len+1]!=-INF)len++; rig_dec[i] = len; } reverse(begin(rig_dec),end(rig_dec)); reverse(begin(a),end(a)); dump(rig_dec); } ll ans = 0; for(int i=1;i+1