Submission

Status:

(PPPPPPPPPP)(PPPPP)(PPPPP)(PPPPPPPPPP)

Subtask/Task Score:

{20/20}{30/30}{30/30}{20/20}

Score: 100

User: C12

Problemset: กองไฟ

Language: cpp

Time: 0.006 second

Submitted On: 2026-01-20 00:13:39

#include <bits/stdc++.h>
using namespace std;

#define f first
#define s second
#define pii pair<ll,ll>
#define puii pair<ull,ull>
#define piii pair<ll,pii>
#define ll long long
#define ull unsigned long long
#define mp make_pair
 
#define mpiii(a,b,c) make_pair(a,make_pair(b,c));
int32_t mod = 1e9+7;

#define SIZE 52

// bool check(int32_t i,int32_t j,int32_t k){
    
// }

int32_t dp[SIZE][SIZE][SIZE][3][3] = {0};

void solve(){
    ll n;
    ll a,b,c;
    
    // cout << "1\n";
    cin >> n;

    cin >> a >> b >> c;

    dp[1][0][0][0][0] = 1;
    dp[0][1][0][1][1] = 1;
    dp[0][0][1][2][2] = 1;
    
    for(int l = 0;l < 3;l++){
        for(int i = 0;i <= a;i++){
            for(int j = 0;j <= b;j++){
                for(int k = 0;k <= c;k++){
                    // if(check(i,j,k)) continue;

                    if(i-1 >= 0) dp[i][j][k][l][0] = max(dp[i][j][k][l][0],(dp[i-1][j][k][l][1] + dp[i-1][j][k][l][2]) % mod);
                    if(j-1 >= 0) dp[i][j][k][l][1] = max(dp[i][j][k][l][1],(dp[i][j-1][k][l][0] + dp[i][j-1][k][l][2]) % mod);
                    if(k-1 >= 0) dp[i][j][k][l][2] = max(dp[i][j][k][l][2],(dp[i][j][k-1][l][0] + dp[i][j][k-1][l][1]) % mod);
                    
                    // cout << i << ' ' << j << ' ' << k << '\t' << dp[i][j][k][0] << ' ' << dp[i][j][k][1] << ' ' << dp[i][j][k][2] << '\n';
                }
            }
        }
    }

    ll aa = a;
    ll bb = b;
    ll cc = c;

    ll out = 0;
    for(int l = 0;l < 3;l++){
        out += (dp[a][b][c][l][0] + dp[a][b][c][l][1] + dp[a][b][c][l][2]) % mod;
    }
    out -= (dp[a][b][c][0][0] + dp[a][b][c][1][1] + dp[a][b][c][2][2]) % mod;
    while(out < 0)out += mod;
    out %= mod;
    
    cout << out;
}
int main() {
    ios::sync_with_stdio(0);
    cin.tie(0);

    // ll q;
 
    // cin >> q;
    
    // while(q--) 
    solve();

    return 0;
}