Submission #343990

#TimeUsernameProblemLanguageResultExecution timeMemory
343990flappybirdmedians (balkan11_medians)C++14
100 / 100
228 ms14188 KiB
#include <bits/stdc++.h> using namespace std; #define MAX 302020 int l[MAX], r[MAX]; int tree[MAX]; int arr[MAX]; int s, d; vector<int>ans; set<int>S; void update(int loc) { ans.push_back(loc); arr[loc] = 1; S.erase(loc); loc += s - 1; while (loc > 0) { tree[loc]++; loc /= 2; } } int lg(int x) { int cnt = 0; while (x) { x /= 2; cnt++; } return cnt - 1; } int sumquery(int low, int high, int loc = 1) { int l, r; int ll, rr; int res = lg(loc); int a = d - res; int pw = 1 << a; l = (loc - (1 << res))*pw; r = l + pw - 1; rr = (l + r) / 2; ll = rr + 1; l++; r++; ll++; rr++; if (l == low && r == high) return tree[loc]; else if (rr >= high) return sumquery(low, high, loc * 2); else if (ll <= low) return sumquery(low, high, loc * 2 + 1); else return sumquery(low, rr, loc * 2) + sumquery(ll, high, loc * 2 + 1); } int minn() { return *S.begin(); } int maxn() { set<int>::iterator it; it = S.end(); it--; return *it; } int main(void) { int N; scanf("%d", &N); d = (int)ceil(log2(2 * N - 1)); s = 1 << d; int i; for (i = 1; i <= 2 * N - 1; i++) S.insert(i); int a; scanf("%d", &a); update(a); int r1, r2; for (i = 1; i <= N - 1; i++) { scanf("%d", &a); if (arr[a] == 0) update(a); r1 = sumquery(1, a); r2 = sumquery(a, 2 * N - 1); while (r1 < (i + 1)) { update(minn()); r1++; } while (r2 < (i + 1)) { update(maxn()); r2++; } } for (auto i : ans) printf("%d\n", i); }

Compilation message (stderr)

medians.cpp: In function 'int main()':
medians.cpp:58:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   58 |  scanf("%d", &N);
      |  ~~~~~^~~~~~~~~~
medians.cpp:64:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   64 |  scanf("%d", &a);
      |  ~~~~~^~~~~~~~~~
medians.cpp:68:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   68 |   scanf("%d", &a);
      |   ~~~~~^~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...