#include "bits/stdc++.h"
using namespace std;
#ifdef duc_debug
#include "bits/debug.h"
#else
#define debug(...)
#endif
const int maxn = 1e5 + 5;
const int mod = 1e9 + 7;
int n, k;
int fact[maxn], inv[maxn];
int C(int n, int k) {
if (n < k) return 0;
return 1ll * fact[n] * inv[k] % mod * inv[n - k] % mod;
}
int add(int x, int y) {
if (y < 0) y += mod;
x = x + y;
if (x >= mod) x -= mod;
return x;
}
int power(int a, int b) {
int res = 1;
while (b) {
if (b & 1) res = 1ll * res * a % mod;
a = 1ll * a * a % mod;
b >>= 1;
}
return res;
}
void solve() {
cin >> n >> k; --k;
int res = 0;
for (int i = 0; i <= k; ++i) {
int cur = 1ll * C(n + 1, i) * power(k - i + 1, n) % mod;
res = add(res, cur * (i & 1 ? -1 : 1));
}
cout << res;
}
signed main() {
ios_base::sync_with_stdio(0);
cin.tie(0);
fact[0] = inv[0] = 1;
for (int i = 1; i < maxn; ++i) {
fact[i] = 1ll * fact[i - 1] * i % mod;
}
inv[maxn - 1] = 931791584;
debug(inv[maxn - 1]);
for (int i = maxn - 2; i; --i) {
inv[i] = 1ll * inv[i + 1] * (i + 1) % mod;
}
solve();
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |