This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
const int MAXSHIPS = 100*1000;
const int MINUSINF = -(MAXSHIPS * 3 + 1);
int nbship;
int ships[MAXSHIPS+1];
int maxcoal[MAXSHIPS+1][4][4][4][4];
string shipstring;
int prodwith(int ship1,int ship2,int ship3)
{
    if(ship3==3 && ship1==ship2)
    {
        return 1;
    }
    else if(ship3==3 && ship2==3)
    {
        return 1;
    }
    else if(ship3==3)
    {
        return 2;
    }
    if(ship1==ship2 && ship1==ship3)
    {
        return 1;
    }
    else if(ship1==ship2 || ship1==ship3 || ship2==ship3)
    {
        return 2;
    }
    else
    {
        return 3;
    }
    
}
signed main()
{
    ios::sync_with_stdio(false);
    cout.tie(nullptr);
    cin.tie(nullptr);
    cin>>nbship>>shipstring;
    for(int iship = 0 ; iship < nbship ; iship++)
    {
        ships[nbship-iship-1]=(shipstring[iship]=='M'?0:(shipstring[iship]=='B'?1:2));
    }
    for(int iship = 0 ; iship < nbship+1 ; iship++)
    {
        for(int i = 0 ; i < 4 ; i++)
        {
            for(int j = 0 ; j < 4 ; j++)
            {
                for(int k = 0 ; k < 4 ; k++)
                {
                    for(int l = 0 ; l < 4 ; l++)
                    {
                        maxcoal[iship][i][j][k][l]=(i==3 && j==3 && k==3 && l==3 ? 0 : MINUSINF);
                    }
                }
            }
        }
    }
    for(int iship = nbship ; iship>0 ; iship--)
    {
        for(int i = 0 ; i < 4 ; i++)
        {
            for(int j = 0 ; j < 4 ; j++)
            {
                for(int k = 0 ; k < 4 ; k++)
                {
                    for(int l = 0 ; l < 4 ; l++)
                    {
                        maxcoal[iship-1][ships[iship-1]][i][k][l] = max(maxcoal[iship-1][ships[iship-1]][i][k][l] ,maxcoal[iship][i][j][k][l]+prodwith(ships[iship-1],i,j));
                        maxcoal[iship-1][i][j][ships[iship-1]][k] = max(maxcoal[iship-1][i][j][ships[iship-1]][k] ,maxcoal[iship][i][j][k][l]+prodwith(ships[iship-1],k,l));
                    }
                }
            }
        }
    }
    int maxi = 0;
    for(int i = 0 ; i < 4 ; i++)
    {
        for(int j = 0 ; j < 4 ; j++)
        {
            for(int k = 0 ; k < 4 ; k++)
            {
                for(int l = 0 ; l < 4 ; l++)
                {
                    maxi = max(maxi,maxcoal[0][i][j][k][l]);
                }
            }
        }
    }
    cout<<maxi;
}
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... |