結果
| 問題 |
No.801 エレベーター
|
| コンテスト | |
| ユーザー |
goodbaton
|
| 提出日時 | 2019-03-17 21:42:10 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 2,613 bytes |
| コンパイル時間 | 1,770 ms |
| コンパイル使用メモリ | 122,480 KB |
| 実行使用メモリ | 10,752 KB |
| 最終ジャッジ日時 | 2024-07-07 21:25:25 |
| 合計ジャッジ時間 | 5,724 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 10 TLE * 1 -- * 15 |
ソースコード
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <cstring>
#include <iostream>
#include <complex>
#include <string>
#include <algorithm>
#include <numeric>
#include <vector>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <unordered_map>
#include <unordered_set>
#include <functional>
#include <cassert>
typedef long long ll;
using namespace std;
#ifndef LOCAL
#define debug(x) ;
#else
#define debug(x) cerr << __LINE__ << " : " << #x << " = " << (x) << endl;
template <typename T1, typename T2>
ostream &operator<<(ostream &out, const pair<T1, T2> &p) {
out << "{" << p.first << ", " << p.second << "}";
return out;
}
template <typename T>
ostream &operator<<(ostream &out, const vector<T> &v) {
out << '{';
for (const T &item : v) out << item << ", ";
out << "\b\b}";
return out;
}
#endif
#define mod 1000000007 //1e9+7(prime number)
#define INF 1000000000 //1e9
#define LLINF 2000000000000000000LL //2e18
#define SIZE 3010
/* Starry Sky Tree */
//0-index
struct StarrySkyTree{
typedef ll Type;
int segn2;
vector<Type> data, s_data;
function<Type(Type, Type)> merge;
StarrySkyTree(function<Type(Type, Type)> merge, int n): merge(merge)
{
for(segn2=1; segn2<n; segn2*=2);
data.assign(segn2*2, 0);
s_data.assign(segn2*2, 0);
}
StarrySkyTree(int n): //Original Ver.
StarrySkyTree([](Type a, Type b){ return a + b; }, n) {}
//get value of [a,b)
Type query(int a, int b, int l = 0, int r = -1, int k = 0){
if(r == -1) r = segn2;
if(r <= a || b <= l) return 0; //大きさに注意
if(a <= l && r <= b) return data[k] + s_data[k] * (r - l);
return merge(query(a, b, l, (l+r)/2, k*2+1), query(a, b, (l+r)/2 , r, k*2+2)) + s_data[k] * (min(b, r) - max(a, l));
}
//add x to [a,b)
Type add(int a, int b, Type x, int l = 0, int r = -1, int k = 0){
if(r == -1) r = segn2;
if(a <= l && r <= b)
s_data[k] += x;
else if(a < r && l < b)
data[k] = merge(add(a, b, x, l, (l+r)/2, k*2+1), add(a, b, x, (l+r)/2, r, k*2+2));
return data[k] + s_data[k] * (r - l);
}
};
int main(){
int N, M, K;
pair<int,int> ele[SIZE];
cin >> N >> M >> K;
for(int i=0;i<M;i++){
int l, r;
cin >> l >> r;
ele[i] = {l-1, r-1};
}
sort(ele, ele + M);
StarrySkyTree seg(N);
seg.add(0, 1, 1);
for(int i=0;i<K;i++){
StarrySkyTree seg2(N);
for(int j=0;j<M;j++){
ll p = seg.query(ele[j].first, ele[j].second+1);
seg2.add(ele[j].first, ele[j].second+1, p%mod);
}
seg = seg2;
}
cout << seg.query(N-1, N) % mod << endl;
return 0;
}
goodbaton