Submission #1274865

#TimeUsernameProblemLanguageResultExecution timeMemory
1274865flaming_top1Zapina (COCI20_zapina)C++20
110 / 110
124 ms1412 KiB
#include <bits/stdc++.h>

#define SPED                                                                                                           \
    ios_base::sync_with_stdio(false);                                                                                  \
    cin.tie(0);                                                                                                        \
    cout.tie(0);

#define endl "\n"
#define fi first
#define se second
#define lint long long
#define fami signed
#define lore main
#define freefire freopen

const lint INF = 0x1f1f1f1f1f1f1f1f;
const lint NEG = 0xE1E1E1E1E1E1E1E1;
const lint mod = 1e9 + 7;

using namespace std;

lint n;
lint dp[355][355], gt[355], inv[355];

lint binpow(lint x, lint k)
{
    if (k == 0)
        return 1;
    lint temp = binpow(x, k >> 1);
    temp *= temp;
    temp %= mod;
    if (k & 1)
    {
        temp *= x;
        temp %= mod;
    }
    return temp;
}

lint C(lint N, lint K)
{
    return ((gt[N] * inv[K]) % mod * inv[N - K]) % mod;
}

fami lore()
{
    SPED;
    cin >> n;

    gt[0] = 1;
    for (int i = 1; i <= 352; i++)
    {
        gt[i] = gt[i - 1] * i;
        gt[i] %= mod;
    }

    inv[352] = binpow(gt[352], mod - 2);
    for (int i = 351; i >= 0; i--)
    {
        inv[i] = inv[i + 1] * (i + 1);
        inv[i] %= mod;
    }

    for (int i = 1; i <= n; i++)
    {
        for (int k = 0; k <= n; k++)
        {
            if (k >= i)
            {
                dp[k][i] += C(k, i) * binpow(i - 1, k - i);
                dp[k][i] %= mod;
            }

            for (int j = 0; j <= k; j++)
            {
                if (j != i)
                {
                    dp[k][i] += (dp[k - j][i - 1] * C(k, j)) % mod;
                    dp[k][i] %= mod;
                }
            }
        }
    }
    cout << dp[n][n];
}
// Let your soul wander where dreams are born.
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...