Submission

Status:

(-SSSSSSSSS)(-SSSS)(-SSSS)(SSSSSSSSSS)

Subtask/Task Score:

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

Score: 0

User: C12

Problemset: กองไฟ

Language: cpp

Time: 0.004 second

Submitted On: 2026-01-19 21:16:59

#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 = (1000 * 1000 * 1000) + 7;

#define SIZE 52

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

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

    cin >> arr[0] >> arr[1] >> arr[2];

    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;
    // }

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

    dp[1][0][0][0] = 1;
    dp[0][1][0][1] = 1;
    dp[0][0][1][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 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][0] = max(dp[i][j][k][0],(dp[i-1][j][k][1] + dp[i-1][j][k][2]) % mod);
                if(j-1 >= 0) dp[i][j][k][1] = max(dp[i][j][k][1],(dp[i][j-1][k][0] + dp[i][j-1][k][2]) % mod);
                if(k-1 >= 0) dp[i][j][k][2] = max(dp[i][j][k][2],(dp[i][j][k-1][0] + dp[i][j][k-1][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;
    }
    cout << ((dp[a][b][c][0] + dp[a][b][c][1] + dp[a][b][c][2]) % mod);
}
int main() {
    ios::sync_with_stdio(0);
    cin.tie(0);

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

    return 0;
}