結果
問題 | No.1290 Addition and Subtraction Operation |
ユーザー |
![]() |
提出日時 | 2020-11-13 22:22:32 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 2,166 bytes |
コンパイル時間 | 1,720 ms |
コンパイル使用メモリ | 176,024 KB |
実行使用メモリ | 10,752 KB |
最終ジャッジ日時 | 2024-07-22 21:12:55 |
合計ジャッジ時間 | 5,997 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 1 TLE * 1 -- * 83 |
ソースコード
// // Created by yamunaku on 2020/11/13. // #include <bits/stdc++.h> //#include <atcoder/all> using namespace std; //using namespace atcoder; #define rep(i, n) for(int i = 0; i < (n); i++) #define repl(i, l, r) for(int i = (l); i < (r); i++) #define per(i, n) for(int i = ((n)-1); i >= 0; i--) #define perl(i, l, r) for(int i = ((r)-1); i >= (l); i--) #define all(x) (x).begin(),(x).end() #define MOD9 998244353 #define MOD1 1000000007 #define IINF 1000000000 #define LINF 1000000000000000000 #define SP <<" "<< #define CYES cout<<"YES"<<endl #define CNO cout<<"NO"<<endl #define CFS cin.tie(0);ios::sync_with_stdio(false) #define CST(x) cout<<fixed<<setprecision(x) using ll = long long; using ld = long double; using vi = vector<int>; using mti = vector<vector<int>>; using vl = vector<ll>; using mtl = vector<vector<ll>>; using pi = pair<int, int>; using pl = pair<ll, ll>; template<typename T> using heap = priority_queue<T, vector<T>, function<bool(const T, const T)>>; int main() { //CFS; int n, m; cin >> n >> m; vl b(n); rep(i, n) { cin >> b[i]; if (i & 1) b[i] = -b[i]; // cout << b[i] << " "; } // cout << endl; vector<priority_queue<int, vi, greater<int>>> v(n + 1); vi l(m), r(m); rep(i, m) { cin >> l[i] >> r[i]; v[l[i] - 1].push(r[i] - 1); } vl rui(n + 1, 0); rep(i, n) { if (i > 0) rui[i] += rui[i - 1]; ll k = b[i] - rui[i]; // cout << i SP k << endl; if (v[i].empty()) { if (k == 0) continue; CNO; return 0; } int rr = v[i].top() + 1; // cout << rr << endl; rui[i] += k; rui[rr] -= k; while (!v[i].empty()) { if (v[i].top() == rr - 1) v[i].pop(); } if (v[i].size() < v[rr].size()) { while (!v[i].empty()) { v[rr].push(v[i].top()); v[i].pop(); } } else { while (!v[rr].empty()) { v[i].push(v[rr].top()); v[rr].pop(); } v[rr] = move(v[i]); } } CYES; return 0; }