제출 #417194

#제출 시각아이디문제언어결과실행 시간메모리
417194pavementEvent Hopping 2 (JOI21_event2)C++17
1 / 100
3104 ms87028 KiB
#include <bits/stdc++.h> #include <ext/pb_ds/assoc_container.hpp> #include <ext/pb_ds/tree_policy.hpp> using namespace std; using namespace __gnu_pbds; #ifdef _WIN32 #define getchar_unlocked _getchar_nolock #endif #define int long long #define mp make_pair #define mt make_tuple #define pb push_back #define ppb pop_back #define eb emplace_back #define g0(a) get<0>(a) #define g1(a) get<1>(a) #define g2(a) get<2>(a) #define g3(a) get<3>(a) mt19937 rng(chrono::steady_clock::now().time_since_epoch().count()); typedef double db; typedef long long ll; typedef long double ld; typedef pair<int, int> ii; typedef tuple<int, int, int> iii; typedef tuple<int, int, int, int> iiii; typedef tree<iii, null_type, greater<iii>, rb_tree_tag, tree_order_statistics_node_update> ordered_set; int N, K, L[500005], R[500005], A[500005], ft2[500005], ft3[500005], occ[500005]; bool rec, inS[500005]; vector<int> ans, v; set<ii> cfm; multiset<ii> ft[500005]; set<iii> S; vector<iii> tmp; bool intersect(int a, int b, int c, int d) { if (a > c) swap(a, c), swap(b, d); return b > c; } inline int ls(int x) { return x & -x; } ii qry(int p) { ii ret = mp(LLONG_MAX, LLONG_MAX); for (; p <= 2 * N; p += ls(p)) if (!ft[p].empty()) ret = min(ret, *ft[p].begin()); return ret; } void potadd(int x) { occ[x]++; for (int p = L[x]; p; p -= ls(p)) ft[p].emplace(R[x], x); } void potdel(int x) { occ[x]--; assert(occ[x] >= 0); for (int p = L[x]; p; p -= ls(p)) { assert(ft[p].find(mp(R[x], x)) != ft[p].end()); ft[p].erase(ft[p].find(mp(R[x], x))); } } int ft2_qry(int p) { int r = 0; for (; p; p -= ls(p)) r += ft2[p]; return r; } void ft2_upd(int p, int v) { for (; p <= 2 * N; p += ls(p)) ft2[p] += v; } int ft3_qry(int p) { p = 2 * N - p + 1; int r = 0; for (; p; p -= ls(p)) r += ft3[p]; return r; } void ft3_upd(int p, int v) { p = 2 * N - p + 1; for (; p <= 2 * N; p += ls(p)) ft3[p] += v; } void addseg(int x) { int lim; auto it = S.lower_bound(mt(R[x], 0ll, 0ll)); if (it == S.end()) lim = LLONG_MAX; else lim = g0(*it); vector<set<iii>::iterator> todel; while (it != S.begin()) { --it; if (intersect(g0(*it), g1(*it), L[x], R[x])) { ft2_upd(g1(*it), -1); ft3_upd(g0(*it), -1); potadd(g2(*it)); todel.pb(it); } else break; } for (auto i : todel) { assert(inS[g2(*i)]); inS[g2(*i)] = 0; S.erase(i); } ft2_upd(R[x], 1); ft3_upd(L[x], 1); S.emplace(L[x], R[x], x); assert(!inS[x]); inS[x] = 1; potdel(x); auto tmp = qry(R[x]); if (tmp.second != LLONG_MAX && tmp.first <= lim) { assert(!rec); rec = 1; addseg(tmp.second); rec = 0; } } main() { ios::sync_with_stdio(0); cin.tie(0); cin >> N >> K; for (int i = 1; i <= N; i++) cin >> L[i] >> R[i], v.pb(L[i]), v.pb(R[i]); sort(v.begin(), v.end()); v.erase(unique(v.begin(), v.end()), v.end()); for (int i = 1; i <= N; i++) { L[i] = lower_bound(v.begin(), v.end(), L[i]) - v.begin() + 1; R[i] = lower_bound(v.begin(), v.end(), R[i]) - v.begin() + 1; tmp.eb(R[i], L[i], i); } sort(tmp.begin(), tmp.end()); int lastr = LLONG_MIN; for (int i = 1; i <= N; i++) potadd(i); for (auto [r, l, i] : tmp) if (lastr <= l) { ft2_upd(R[i], 1); ft3_upd(L[i], 1); inS[i] = 1; S.emplace(l, r, i); potdel(i); lastr = r; } int top = S.size(); if (S.size() < K) return cout << "-1\n", 0; for (int i = 1; i <= N; i++) { auto it = cfm.lower_bound(mp(R[i], 0ll)); bool yep = 1; if (it != cfm.begin()) { --it; if (intersect(it->first, it->second, L[i], R[i])) yep = 0; } if (!yep) { for (int j = 1; j <= N; j++) if (inS[j]) assert(occ[j] == 0); else assert(occ[j] == 1); continue; } A[i] = ft2_qry(L[i]) + ft3_qry(R[i]) + 1; auto tmp = qry(R[i]); auto it2 = S.lower_bound(mt(R[i], 0ll, 0ll)); if (tmp.second != LLONG_MAX && (it2 == S.end() || tmp.first <= g0(*it2))) A[i]++; assert(A[i] <= top); if (A[i] >= K) { cfm.emplace(L[i], R[i]); ans.pb(i); addseg(i); } for (int j : ans) assert(cfm.find(mp(L[j], R[j])) != cfm.end()); for (int j = 1; j <= N; j++) if (inS[j]) assert(occ[j] == 0); else assert(occ[j] == 1); } assert(ans.size() >= K); for (int i = 0; i < K; i++) cout << ans[i] << '\n'; }

컴파일 시 표준 에러 (stderr) 메시지

event2.cpp:122:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
  122 | main() {
      | ^~~~
event2.cpp: In function 'int main()':
event2.cpp:147:15: warning: comparison of integer expressions of different signedness: 'std::set<std::tuple<long long int, long long int, long long int> >::size_type' {aka 'long unsigned int'} and 'long long int' [-Wsign-compare]
  147 |  if (S.size() < K) return cout << "-1\n", 0;
      |      ~~~~~~~~~^~~
In file included from /usr/include/c++/10/ext/pb_ds/detail/pat_trie_/pat_trie_.hpp:45,
                 from /usr/include/c++/10/ext/pb_ds/detail/container_base_dispatch.hpp:90,
                 from /usr/include/c++/10/ext/pb_ds/assoc_container.hpp:48,
                 from event2.cpp:2:
event2.cpp:176:20: warning: comparison of integer expressions of different signedness: 'std::vector<long long int>::size_type' {aka 'long unsigned int'} and 'long long int' [-Wsign-compare]
  176 |  assert(ans.size() >= K);
      |         ~~~~~~~~~~~^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...