CODERE3 - Coder Express 3!! - SPOJ Solution C++

  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!!