結果
問題 | No.391 CODING WAR |
ユーザー |
![]() |
提出日時 | 2022-10-26 16:04:27 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 129 ms / 2,000 ms |
コード長 | 6,205 bytes |
コンパイル時間 | 3,777 ms |
コンパイル使用メモリ | 253,900 KB |
最終ジャッジ日時 | 2025-02-08 12:47:39 |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 16 |
ソースコード
// 2022.10.21// #define _GLIBCXX_DEBUG //// #define __USE_MATH_DEFINES // const double PI = acos(-1.0)#include <bits/stdc++.h>using namespace std;// (*) snipet// type nameusing ll = long long;using pii = pair<int, int>; using pil = pair<int, ll>; using pli = pair<ll, int>; using pll = pair<ll, ll>;using vi = vector<int>; using vvi = vector<vi>; using vvvi = vector<vvi>;using vl = vector<ll>; using vvl = vector<vl>; using vvvl = vector<vvl>;using vpii = vector<pii>; using vpil = vector<pil>; using vpli = vector<pli>; using vpll = vector<pll>;using vb = vector<bool>; using vvb = vector<vb>; using vvvb = vector<vvb>;using vd = vector<double>; using vvd = vector<vd>; using vvvd = vector<vvd>;template <typename T> using pq = priority_queue<T, vector<T>>;template <typename T> using pql = priority_queue<T, vector<T>, greater<T>>;// rep#define rep0(goal) for (int cnt = 0; cnt < int(goal); ++cnt)#define rep(cnt, goal) for (int cnt = 0; cnt < int(goal); ++cnt)#define rep2(cnt, start, goal) for (int cnt = int(start); cnt < int(goal); ++cnt)#define rep3(cnt, start, goal) for (int cnt = int(start); cnt > int(goal); --cnt)// all#define all(ctn) begin(ctn), end(ctn)// chmax, chmintemplate <typename T> bool chmax(T &x, const T y) { if (x < y) { x = y; return true; } else { return false; }}template <typename T> bool chmin(T &x, const T y) { if (x > y) { x = y; return true; } else { return false; }}// etc.void Yn(const bool &exp) { if (exp) cout << "Yes" << endl; else cout << "No" << endl;}void set_prec(const int &dig) { cout << fixed << setprecision(dig); cerr << fixed << setprecision(dig);}// template <typename T> T INF() { return numeric_limits<T>::max();}// template <typename T> T MIN_INF() { return numeric_limits<T>::min();}#include <atcoder/all>using namespace atcoder;// using mint = atcoder::modint1000000007;using mint = atcoder::modint998244353;// using mint = atcoder::modint;void pr(const mint &MINT) { cerr << MINT.val(); } // mintusing pmm = pair<mint, mint>; using pim = pair<int, mint>; using pmi = pair<mint, int>; using plm = pair<ll, mint>; using pml = pair<mint, ll>;using vm = vector<mint>; using vvm = vector<vm>; using vvvm = vector<vvm>;// debugtemplate <typename T> void pr(const T &obj) { cerr << obj; } // singletemplate <typename T, typename ...Ts> void pr(const T &first, const Ts &...rest) { pr(first); cerr << ", "; pr(rest...); } // multi(plural)template <typename S, typename T> void pr(const pair<S, T> &PAIR) { cerr << "("; pr(PAIR.first); cerr << ", "; pr(PAIR.second); cerr << ")"; } //pairtemplate <typename S, typename T, typename U> void pr(const tuple<S, T, U> &trp) { cerr << "("; pr(get<0>(trp)); cerr << ", "; pr(get<1>(trp)); cerr<< ", "; pr(get<2>(trp)); cerr << ")"; } // tuple(3)template <typename T> void pr(const vector<T> &vec) { cerr << "{"; for (T obj : vec) { pr(obj); cerr << ", "; } cerr << "}"; } // vectortemplate <typename T> void pr(const vector<vector<T>> &vv) { rep(row, vv.size()) { cerr << endl; cerr << "[" << row << "]: "; pr(vv[row]); }} //vector(multi-D)template <typename T> void pr(const set<T> &SET) { cerr << "{"; for (T obj : SET) { pr(obj); cerr << ", "; } cerr << "}"; } // settemplate <typename T> void pr(const multiset<T> &MS) { cerr << "{"; for (T obj : MS) { pr(obj); cerr << ", "; } cerr << "}"; } // multisettemplate <typename S, typename T> void pr(const map<S, T> &MAP) { cerr << "{"; for (pair<S, T> p : MAP) { pr(p.first); cerr << ": "; pr(p.second);cerr << ", "; } cerr << "}";} // maptemplate <typename T> void pr(const queue<T> &que) { queue<T> q = que; cerr << "{"; while (!q.empty()) { pr(q.front()); q.pop(); cerr << ", ";} cerr<< "}";} // queuetemplate <typename T> void pr(const deque<T> &deq) { deque<T> d = deq; cerr << "{"; while (!d.empty()) { pr(d.front()); d.pop_front(); cerr << ", ";}cerr << "}";} // dequetemplate <typename T> void pr(const stack<T> &stc) { stack<T> s = stc; vector<T> v; while (!s.empty()) { v.push_back(s.top()); s.pop();} reverse(all(v)); cerr << "{"; for (T obj : v) cerr << obj << ", "; cerr << "}";} // stacktemplate <typename T> void pr(const priority_queue<T> &pq) { priority_queue<T> p = pq; cerr << "{"; while (!p.empty()) { pr(p.top()); p.pop(); cerr<< ", "; } cerr << "}";} // priority_queuetemplate <typename T> void pr(const priority_queue<T, vector<T>, greater<T>> &pq) { priority_queue<T, vector<T>, greater<T>> p = pq; cerr << "{";while (!p.empty()) { pr(p.top()); p.pop(); cerr << ", ";} cerr << "}";} // priority_queue(from less)#define db(obj) cerr << #obj << ": "; pr(obj); cerr << " ";#define dl(obj) db(obj); cerr << endl;#define dm(...) cerr << "(" << #__VA_ARGS__ << "): ("; pr(__VA_ARGS__); cerr << ") ";#define dml(...) dm(__VA_ARGS__); cerr << endl;// N元集合からM元集合への全射の数// N -> n, M -> k// globalll N;int M;vl fac; // fac[i] = i!vl inv; // inv[i] = 1/i! mod mll m = 1e9 + 7; // 998244353; // MODvoid input() {cin >> N >> M;}ll my_pow_mod(ll x, ll n, ll m) {assert(0 <= n); assert(1 <= m);ll res = 1;ll y = x % m;if (x < 0) x += m;while (n) {if (n % 2) {res = (res * y) % m;}n /= 2;y = (y * y) % m;}return res;}ll my_inv_mod(ll x, ll m) {assert(1 <= m);assert(x % m != 0); // m: 素数return my_pow_mod(x, m - 2, m);// assert(my_gcd(x, m) == 1);// return my_pow_mod(x, phi(m) - 1, m);}// factorial, inv_factorialvl my_facts(int N) {assert(0 <= N);vl res(N + 1);res[0] = 1;rep(i, N) res[i + 1] = (res[i] * (i + 1)) % m;return res;}vl my_inv_facts(int N) {assert(0 <= N);vl res(N + 1);res[0] = 1;rep(i, N) res[i + 1] = (res[i] * my_inv_mod(i + 1, m)) % m;return res;}void init() {fac = my_facts(M + 1);inv = my_inv_facts(M + 1);}ll surjection(ll n, int k) { // O(k*logn)assert(0 <= n); assert(0 <= k);// if (n < k) return 0;ll res = 0;rep(i, k + 1) {ll temp = ((fac[k] * inv[k - i] % m) * inv[i] % m);temp = (temp * my_pow_mod(i, n, m)) % m;if ((k - i) % 2 == 0) res = (res + temp) % m;else res = (res - temp + m) % m;}return res;}void solve() {cout << surjection(N, M) << endl;};int main() {input();init();solve();}