Advertisement
pb_jiang

ABC372F AC

Oct 1st, 2024
89
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.92 KB | None | 0 0
  1. #include <assert.h>
  2. #include <bits/stdc++.h>
  3. using namespace std;
  4. #ifndef __DEBUG__
  5. #define dbg(...) 42
  6. #endif
  7. template <class T>
  8. using mpq = priority_queue<T, vector<T>, greater<T>>;
  9.  
  10. using ll = long long;
  11. using pii = pair<int, int>;
  12. using pll = pair<ll, ll>;
  13. using vl = vector<ll>;
  14. using vi = vector<int>;
  15.  
  16. int main(int argc, char** argv)
  17. {
  18.     ll n, m, k;
  19.     cin >> n >> m >> k;
  20.     using a2l = array<ll, 2>;
  21.     vl ns { 1 };
  22.     vector<a2l> sc(m);
  23.     for (auto& v : sc)
  24.         cin >> v[0] >> v[1], ns.push_back(v[0]), ns.push_back(v[1]);
  25.  
  26.     sort(ns.begin(), ns.end());
  27.     ns.erase(std::unique(ns.begin(), ns.end()), ns.end());
  28.     ll sz = ns.size();
  29.     if (sz == 1) {
  30.         cout << 1 << '\n';
  31.         return 0;
  32.     }
  33.  
  34.     vector<vector<a2l>> g(sz);
  35.     for (auto& short_cut : sc) {
  36.         ll u = lower_bound(ns.begin(), ns.end(), short_cut[0]) - ns.begin(),
  37.            v = lower_bound(ns.begin(), ns.end(), short_cut[1]) - ns.begin();
  38.         // u -> v
  39.         // if (v - u != 1) // FIXME: WA here
  40.         if (short_cut[1] - short_cut[0])
  41.             g[u].push_back({ v, 1 });
  42.     }
  43.     for (ll i = 0; i < sz; ++i) {
  44.         ll u = i, v = (i + 1) % sz;
  45.         g[u].push_back({ v, (ns[v] - ns[u] + n) % n });
  46.     }
  47.     dbg(g);
  48.  
  49.     vector<vl> cache(sz, vl(k + 1, -1));
  50.  
  51.     constexpr ll mod = 998244353;
  52.     auto search = [&](auto&& self, ll u, ll remk) {
  53.         if (cache[u][remk] != -1)
  54.             return cache[u][remk];
  55.  
  56.         ll ret = 0;
  57.         for (auto [v, w] : g[u]) {
  58.             if (w >= remk)
  59.                 ret = (ret + 1) % mod;
  60.             else
  61.                 ret = (ret + self(self, v, remk - w)) % mod;
  62.         }
  63.         return cache[u][remk] = ret;
  64.     };
  65.  
  66.     // cout << search(search, 0, k) << '\n';
  67.     ll ans = 0;
  68.     vector<vl> cnt(sz, vl(k + 1));
  69.     /*
  70.     auto search2 = [&](ll u, ll remk) -> void {
  71.         priority_queue<a2l> pq;
  72.         pq.push({ remk, u });
  73.         cnt[u][remk] += 1;
  74.         while (!pq.empty()) {
  75.             auto [rk, u] = pq.top();
  76.             pq.pop();
  77.             for (auto [v, w] : g[u]) {
  78.                 if (rk <= w) {
  79.                     ans = (ans + cnt[u][rk]) % mod;
  80.                 } else {
  81.                     if (cnt[v][rk - w] == 0)
  82.                         pq.push({ rk - w, v });
  83.                     cnt[v][rk - w] = (cnt[v][rk - w] + cnt[u][rk]) % mod;
  84.                 }
  85.             }
  86.         }
  87.     };
  88.     */
  89.     // --k;
  90.     cnt[0][k] = 1;
  91.     for (ll vk = k; vk >= 0; --vk) {
  92.         for (ll u = 0; u < sz; ++u) {
  93.             for (auto [v, w] : g[u]) {
  94.                 if (vk <= w)
  95.                     ans = (ans + cnt[u][vk]) % mod;
  96.                 else
  97.                     cnt[v][vk - w] = (cnt[v][vk - w] + cnt[u][vk]) % mod;
  98.             }
  99.         }
  100.     }
  101.     // for (ll u = 0; u < sz; ++u)
  102.     // ans = (ans + cnt[u][0]) % mod;
  103.     // search2(0, k);
  104.     cout << ans << '\n';
  105.     return 0;
  106. };
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement