Submission #890779

# Submission time Handle Problem Language Result Execution time Memory
890779 2023-12-22T03:07:14 Z Sir_Ahmed_Imran Miners (IOI07_miners) C++17
84 / 100
1500 ms 100444 KB
                              ///~~~LOTA~~~///
#include <bits/stdc++.h>
using namespace std;
#define nl '\n'
#define ff first
#define ss second
#define ll long long 
#define append push_back
#define all(x) (x).begin(),(x).end()
#define N 100001
int dp[N][4][4][4][4];
int c(int n,int m,int o){
    set<int> s;
    if(n) s.insert(n);
    if(m) s.insert(m);
    if(o) s.insert(o);
    return s.size();
}
map<char,int> x;
void solve(){
    char s;
    int n,m,o,p,q,r;
    cin>>n;
    x['M']=1;
    x['F']=2;
    x['B']=3;
    for(int i=0;i<=n;i++)
        for(int j=0;j<4;j++)
            for(int k=0;k<4;k++)
                for(int l=0;l<4;l++)
                    for(int t=0;t<4;t++)
                        dp[i][j][k][l][t]=-1e9;
    dp[0][0][0][0][0]=0;
    for(int i=0;i<n;i++){
        cin>>s;
        m=x[s];
        for(int j=0;j<4;j++){
            for(int k=0;k<4;k++){
                for(int l=0;l<4;l++){
                    for(int t=0;t<4;t++){
                        dp[i+1][k][m][l][t]=max(dp[i+1][k][m][l][t]
                        ,dp[i][j][k][l][t]+c(j,k,m));
                        dp[i+1][j][k][t][m]=max(dp[i+1][j][k][t][m]
                        ,dp[i][j][k][l][t]+c(l,t,m));
                    }
                }
            }
        }
    }
    for(int i=o=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++)
                    o=max(o,dp[n][i][j][k][l]);
    cout<<o;
}
int main(){
    ios_base::sync_with_stdio(false);cin.tie(NULL);
    solve();
    return 0;
}

Compilation message

miners.cpp: In function 'void solve()':
miners.cpp:22:15: warning: unused variable 'p' [-Wunused-variable]
   22 |     int n,m,o,p,q,r;
      |               ^
miners.cpp:22:17: warning: unused variable 'q' [-Wunused-variable]
   22 |     int n,m,o,p,q,r;
      |                 ^
miners.cpp:22:19: warning: unused variable 'r' [-Wunused-variable]
   22 |     int n,m,o,p,q,r;
      |                   ^
# Verdict Execution time Memory Grader output
1 Correct 1 ms 348 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 1 ms 348 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 1 ms 348 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 1 ms 348 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 1 ms 348 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 1 ms 348 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 25 ms 2648 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 125 ms 6772 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 244 ms 10840 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 659 ms 27384 KB Output is correct
# Verdict Execution time Memory Grader output
1 Execution timed out 1541 ms 76380 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1557 ms 100444 KB Time limit exceeded
2 Halted 0 ms 0 KB -