結果
問題 |
No.801 エレベーター
|
ユーザー |
|
提出日時 | 2019-07-14 14:52:58 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 952 bytes |
コンパイル時間 | 2,255 ms |
コンパイル使用メモリ | 201,532 KB |
最終ジャッジ日時 | 2025-01-07 06:54:27 |
ジャッジサーバーID (参考情報) |
judge2 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 10 TLE * 16 |
ソースコード
#include <bits/stdc++.h> using namespace std; int main() { int N, M, K; cin>> N >> M >> K; vector<int> L(M), R(M); vector<vector<long long >> dp(3001, vector<long long>(3001, -1)); for (int i = 0; i < M; i++) cin >> L[i] >> R[i]; for (int i = 0; i < M; i++) dp[K][i] = (N <= R[i]) ? 1 : 0; auto solve = [&](auto f, int k, int m) { if (dp[k][m] >= 0) return dp[k][m]; long long r = 0LL; for (int i = 0; i < M; i++) if (min(R[m], R[i]) >= max(L[m], L[i])) r = (r + f(f, k + 1, i) * (min(R[m], R[i]) - max(L[m], L[i]) + 1) % 1000000007) % 1000000007;; dp[k][m] = r; return r; }; long long r = 0; for (int i = 0; i < M; i++) if (1 >= L[i]) r = (r + solve(solve, 1, i)) % 1000000007; cout << r << endl; return 0; }