Submission

Status:

(PPPPPPPPPP)(PPPPP)(PPPPP)(PPPPPPP-SS)

Subtask/Task Score:

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

Score: 80

User: C12

Problemset: กองไฟ

Language: cpp

Time: 0.005 second

Submitted On: 2026-01-20 00:08:15

#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;

    // sort(arr.begin(),arr.end());

    // a = arr[0];
    // b = arr[1];
    // c = arr[2];

    // cout << a << b << c << '\n';

    // if(a + b < c){
    //     cout << "0"; return;
    // }

    dp[1][0][0][0][0] = 1;
    dp[0][1][0][1][1] = 1;
    dp[0][0][1][2][2] = 1;
    
    // dp[1][1][0][0] = 2;
    // dp[1][1][0][1] = 2;
    
    // dp[1][0][1][0] = 2;
    // dp[1][0][1][2] = 2;

    // dp[0][1][1][1] = 2;
    // dp[0][1][1][2] = 2;

    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;

    // while(aa-2 >= 0){
    //     dp[a][b][c][0] -= (dp[aa-2][b][c][1] + dp[a-2][b][c][2]) - dp[aa-2][b][c][0];
    //     while(dp[a][b][c][0] < 0){
    //         dp[a][b][c][0] += mod;
    //     }
    //     dp[a][b][c][0] %= mod;
    //     aa -= 2;
    // }
    // while(bb-2 >= 0){
    //     dp[a][b][c][1] -= (dp[a][bb-2][c][0] + dp[a][bb-2][c][2]) - dp[a][bb-2][c][1];
    //     while(dp[a][b][c][1] < 0){
    //         dp[a][b][c][1] += mod;
    //     }
    //     dp[a][b][c][1] %= mod;
    //     bb -= 2;
    // }
    // while(cc-2 >= 0){ 
    //     dp[a][b][c][2] -= (dp[a][b][cc-2][0] + dp[a][b][cc-2][1]) - dp[a][b][cc-2][2];
    //     while(dp[a][b][c][2] < 0){
    //         dp[a][b][c][2] += mod;
    //     }
    //     dp[a][b][c][2] %= mod;
    //     cc -= 2;
    // }
    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;
    cout << out;
}
int main() {
    ios::sync_with_stdio(0);
    cin.tie(0);

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

    return 0;
}