제출 #1349154

#제출 시각아이디문제언어결과실행 시간메모리
1349154rahidilbayramliTents (JOI18_tents)C++20
48 / 100
313 ms219396 KiB
#include<bits/stdc++.h>
#define ll long long
#define ld long double
#define vl vector<ll>
#define vi vector<int>
#define pb push_back
#define sz(v) (ll)(v.size())
#define f first
#define s second
#define pll pair<ll, ll>
#define pii pair<int, int>
#define all(v) v.begin(), v.end()
#define rall(v) v.rbegin(), v.rend()
using namespace std;
const ll sz = 305, mod = 1000000007;
ll dp[sz][sz][sz];
ll f(ll i, ll j, ll k)
{
    if(i < 0 || j < 0 || k < 0)
        return 0;
    if(i == 0)
        return 1;
    ll &res = dp[i][j][k];
    if(res != -1)
        return res % mod;
    res = f(i-1, j, k);
    res %= mod;
    if(k >= 1)
    {
        res += (k * f(i-1, j, k-1));
        res %= mod;
    }
    if(j >= 1)
    {
        res += (3 * j * f(i-1, j-1, k));
        res %= mod;
        res += (j * f(i-1, j-1, k+1));
        res %= mod;
    }
    if(j >= 2)
    {
        res += (((j * (j - 1)) / 2) * (f(i-1, j-2, k)));
        res %= mod;
    }
    return res;
}
void solve()
{
    ll h, w;
    cin >> h >> w;
    for(ll i = 0; i <= h + 1; i++)
    {
        for(ll j = 0; j <= w + 1; j++)
        {
            for(ll k = 0; k <= w + 1; k++)
                dp[i][j][k] = -1;
        }
    }
    ll ans = f(h, w, 0);
    ans--;
    if(ans < 0)
        ans += mod;
    cout << ans << "\n";
}
int main()
{
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    ll tests = 1;
    //cin >> tests;
    while(tests--)
    {
        solve();
    }
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...