Submission
Status:
(-SSSSSSSSS)(PP-SS)(PPPPP)(SSSSSSSSSS)
Subtask/Task Score:
{0/20}{0/30}{30/30}{0/20}
Score: 30
User: C12
Problemset: กองไฟ
Language: cpp
Time: 0.003 second
Submitted On: 2026-01-19 16:50:37
#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';
}
}
}
if(a-2 >= 0) dp[a][b][c][0] -= (dp[a-2][b][c][1] + dp[a-2][b][c][2]) - dp[a-2][b][c][0];
if(b-2 >= 0) dp[a][b][c][1] -= (dp[a][b-2][c][0] + dp[a][b-2][c][2]) - dp[a][b-2][c][1];
if(c-2 >= 0) dp[a][b][c][2] -= (dp[a][b][c-2][0] + dp[a][b][c-2][1]) - dp[a][b][c-2][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;
}