結果
問題 |
No.674 n連勤
|
ユーザー |
|
提出日時 | 2018-09-25 08:38:11 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 92 ms / 2,000 ms |
コード長 | 707 bytes |
コンパイル時間 | 632 ms |
コンパイル使用メモリ | 76,228 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-02 07:18:37 |
合計ジャッジ時間 | 2,217 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 17 |
ソースコード
#include<iostream> #include<set> using namespace std; typedef long long ll; const ll INF = 1ll<<60; int main(){ set<pair<ll,ll>> job; // sentinel job.emplace(-2,-2); job.emplace(INF,INF); ll d, a, b, ans = 0; int q; cin >> d >> q; for(int i = 0; i < q; i++){ cin >> a >> b; job.emplace(a,b); auto it = job.lower_bound({a,-1}); it--; if(it->second + 1 >= a) a = it->first; else it++; while(b+1 >= it->first){ b = max(b, it->second); it = job.erase(it); } job.emplace(a,b); ans = max(ans, b-a+1); cout << ans << endl; } return 0; }