➤ Problem Link : CODERE3
👉 Hint : Simple DP Problem
✅ C++ Solution :
#include<bits/stdc++.h> using namespace std; int arr[1001]; pair<int,int> dp[1001]; int main() { int t; cin>>t; while(t--) { int n,ans=0; cin>>n; for(int i=0;i<n;i++) cin>>arr[i]; for(int i=0;i<n;i++) { dp[i].first=1; for(int j=i-1;j>=0;j--) if(arr[j]<arr[i]) dp[i].first=max(dp[i].first,1+dp[j].first); } for(int i=n-1;i>=0;i--) { dp[i].second=1; for(int j=i+1;j<n;j++) if(arr[j]<arr[i]) dp[i].second=max(dp[i].second,1+dp[j].second); } for(int i=0;i<n;i++) ans=max(ans,dp[i].first+dp[i].second-1); cout<<ans<<endl; } }
Thank you for your patience reading. If you enjoyed this post, I’d be very grateful if you’d help it spread by emailing it to a friend, or sharing it on Whatsapp or Facebook.
😇Happy Learning!!