Submission #1018045

#TimeUsernameProblemLanguageResultExecution timeMemory
1018045DorostWefTeams (IOI15_teams)C++17
77 / 100
1368 ms524288 KiB
#include "teams.h" #include <bits/stdc++.h> using namespace std; typedef long long ll; typedef pair <int, int> pii; #define F first #define S second const int MXN = 500005, SegN = (1 << 20), LG = 19; pii a[MXN]; int n; vector <int> seg[SegN]; bool f[SegN]; int e[SegN], ans[SegN]; vector <int> vv; int cnt (int v, int x) { if (seg[v].empty()) return 0; return (upper_bound (seg[v].begin(), seg[v].end(), x)) - (upper_bound (seg[v].begin(), seg[v].end(), e[v])) - ans[v]; } void shift (int v) { vv.push_back(v); vv.push_back(v * 2); vv.push_back(v * 2 + 1); if (e[v] > e[v * 2]) { e[v * 2] = e[v]; ans[v * 2] = 0; } if (e[v] > e[v * 2 + 1]) { e[v * 2 + 1] = e[v]; ans[v * 2 + 1] = 0; } } int find (int x) { int k = x; int v = (1 << LG) + (lower_bound (a, a + n, make_pair(x, 0)) - a); while (true) { while (v % 2 == 0) v /= 2; vector <int> wef; int few = v; while (few > 1) { few /= 2; wef.push_back(few); } reverse(wef.begin(), wef.end()); for (int ff : wef) shift (ff); int w = cnt(v, x); if (w >= k) { break; } else { if (f[v]) { return MXN; } e[v] = x; for (int ff : wef) { ans[ff] += w; } ans[v] = 0; k -= w; v /= 2; ++v; } } while (v < (1 << LG)) { shift (v); int w = (cnt (v * 2, x)); vector <int> wef; int few = v; while (few) { wef.push_back(few); few /= 2; } if (w >= k) { v *= 2; } else { v *= 2; e[v] = x; for (int ff : wef) ans[ff] += w; ans[v] = 0; v++; k -= w; } } vector <int> wef; int few = v; while (few > 1) { few /= 2; wef.push_back(few); } int w = 1; e[v] = x; for (int ff : wef) ans[ff] += w; ans[v] = 0; return (v - (1 << LG)); } void init(int N, int A[], int B[]) { for (int i = 0; i <= 20; i++) { f[(1 << i) - 1] = true; } n = N; for (int i = 0; i < n; i++) { a[i].F = B[i]; a[i].S = A[i]; } sort (a, a + n); for (int i = SegN - 1; i >= 0; i--) { if (i >= (1 << LG)) { if ((i - (1 << LG)) < n) { seg[i] = {a[i - (1 << LG)].S}; } } else { merge (seg[i << 1].begin(), seg[i << 1].end(), seg[i << 1 | 1].begin(), seg[i << 1 | 1].end(), back_inserter(seg[i])); } } } int can(int M, int K[]) { vv.clear(); sort (K, K + M); bool h = true; int st = 0; for (int i = 0; i < M; i++) { st = find (K[i]); if (st > n) h = false; else if (a[st].F < K[i]) h = false; } for (int v : vv) { e[v] = 0; ans[v] = 0; } return h; }

Compilation message (stderr)

teams.cpp: In function 'int cnt(int, int)':
teams.cpp:21:110: warning: conversion from '__gnu_cxx::__normal_iterator<int*, std::vector<int> >::difference_type' {aka 'long int'} to 'int' may change value [-Wconversion]
   21 |  return (upper_bound (seg[v].begin(), seg[v].end(), x)) - (upper_bound (seg[v].begin(), seg[v].end(), e[v])) - ans[v];
      |         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~
teams.cpp: In function 'int find(int)':
teams.cpp:40:20: warning: conversion from 'long int' to 'int' may change value [-Wconversion]
   40 |  int v = (1 << LG) + (lower_bound (a, a + n, make_pair(x, 0)) - a);
      |          ~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...