Submission #944248

#TimeUsernameProblemLanguageResultExecution timeMemory
944248Zero_OPMeteors (POI11_met)C++14
74 / 100
724 ms25868 KiB
#include<bits/stdc++.h> using namespace std; using int64 = int64_t; #define REP(i, n) for(int i = 0, _n = n; i < _n; ++i) #define REPD(i, n) for(int i = n - 1; i >= 0; --i) #define FOR(i, l, r) for(int i = l, _r = r; i <= _r; ++i) #define FORD(i, r, l) for(int i = r, _l = l; i >= _l; --i) #define left __left #define right __right #define prev __prev #define next __next #define div __div #define pb push_back #define pf push_front #define sz(v) (int)v.size() #define range(v) begin(v), end(v) #define compact(v) v.erase(unique(range(v)), end(v)) #define debug(v) "[" #v " = " << (v) << "]" template<typename T> bool minimize(T& a, const T& b){ if(a > b){ a = b; return true; } return false; } template<typename T> bool maximize(T& a, const T& b){ if(a < b){ a = b; return true; } return false; } template<int dimension, class T> struct vec : public vector<vec<dimension - 1, T>> { static_assert(dimension > 0, "Dimension must be positive !\n"); template<typename... Args> vec(int n = 0, Args... args) : vector<vec<dimension - 1, T>>(n, vec<dimension - 1, T>(args...)) {} }; template<class T> struct vec<1, T> : public vector<T> { vec(int n = 0, T val = T()) : vector<T>(n, val) {} }; void init(void); void process(void); int main(){ ios_base::sync_with_stdio(0); cin.tie(0); #define task "antuvu" if(fopen(task".inp", "r")){ freopen(task".inp", "r", stdin); freopen(task".out", "w", stdout); } int T = 1; //cin >> T; while(T--) { init(); process(); } return 0; } struct FenwickTree{ vector<int64> bit; FenwickTree(int n) : bit(n + 1, 0) {} void update(int id, int64 val){ for(; id < sz(bit); id += id & (-id)){ bit[id] += val; } } int64 query(int id){ int64 sum = 0; for(; id > 0; id -= id & (-id)){ sum += bit[id]; } return sum; } void update_range(int l, int r, int64 val){ if(l <= r){ update(l, val); update(r + 1, -val); } else{ swap(l, r); update(1, val); update(l + 1, -val); update(r, val); } } }; const int MAX = 3e5 + 5; int n, m, k, o[MAX], p[MAX], u[MAX], v[MAX], c[MAX], l[MAX], r[MAX], mid[MAX], ans[MAX]; vector<int> owned_sections[MAX]; void init(){ cin >> n >> m; FOR(i, 1, m){ cin >> o[i]; owned_sections[o[i]].pb(i); } FOR(i, 1, n){ cin >> p[i]; } cin >> k; FOR(i, 1, k){ cin >> u[i] >> v[i] >> c[i]; } } void parallel_binary_search(){ FOR(i, 1, n){ l[i] = 1; r[i] = k; ans[i] = -1; } while(true){ vector<int> query_indices; FOR(i, 1, n){ if(l[i] <= r[i]){ mid[i] = (l[i] + r[i]) >> 1; query_indices.pb(i); } } if(query_indices.empty()) break; sort(range(query_indices), [&](int i, int j){ return mid[i] < mid[j]; }); FenwickTree BIT(m); int j = 1; REP(i, sz(query_indices)){ int id = query_indices[i]; while(j <= mid[id]){ BIT.update_range(u[j], v[j], c[j]); ++j; } int64 sum = 0; for(int x : owned_sections[id]){ sum += BIT.query(x); } if(sum >= p[id]){ r[id] = mid[id] - 1; ans[id] = mid[id]; } else l[id] = mid[id] + 1; } } } void process(){ parallel_binary_search(); FOR(i, 1, n){ if(ans[i] == -1) cout << "NIE\n"; else cout << ans[i] << '\n'; } }

Compilation message (stderr)

met.cpp: In function 'int main()':
met.cpp:60:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   60 |         freopen(task".inp", "r", stdin);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
met.cpp:61:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   61 |         freopen(task".out", "w", stdout);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...