#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(n),rig(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[i] = len; } dump(lef); } { 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[i] = len; } reverse(begin(rig),end(rig)); reverse(begin(a),end(a)); dump(rig); } ll ans = 0; for(int i=1;i+1(rig[i-1],lef[n-1]-lef[i]); ll tapu = min(lef[i-1],rig[i+1]); ll nichia = max(ushi,tapu); chmax(ans,nichia); } cout<<(ans)<