結果
問題 | No.274 The Wall |
ユーザー |
|
提出日時 | 2019-09-25 13:59:57 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 3 ms / 2,000 ms |
コード長 | 949 bytes |
コンパイル時間 | 804 ms |
コンパイル使用メモリ | 80,132 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-06-22 02:32:57 |
合計ジャッジ時間 | 1,709 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 22 |
ソースコード
#include<iostream> #include<vector> #include<algorithm> using namespace std; int main(){ int n, m; cin >> n >> m; vector<bool> w(m, 0); vector<pair<int,int>> vp; for(int i = 0; i < n; i++){ int x, y; cin >> x >> y; if(m-1-y < x){ swap(x, y); x = m-1-x; y = m-1-y; } vp.push_back({x, y}); } sort(vp.begin(), vp.end()); for(int i = 0; i < n; i++){ int l = vp[i].first, r = vp[i].second; bool ok = true; for(int j = l; j <= r; j++) ok &= !w[j]; if(ok){ for(int j = l; j <= r; j++) w[j] = true; continue; } ok = true; for(int j = l; j <= r; j++) ok &= !w[m-1-j]; if(ok){ for(int j = l; j <= r; j++) w[m-1-j] = true; continue; } cout << "NO" << endl; return 0; } cout << "YES" << endl; return 0; }