Submission #933467

#TimeUsernameProblemLanguageResultExecution timeMemory
933467AtabayRajabliA Difficult(y) Choice (BOI21_books)C++17
100 / 100
1 ms856 KiB
#include <bits/stdc++.h> #include "books.h" using namespace std; const int sz = 1e5 + 5; long long q[sz]; long long get(long long x) { if(q[x])return q[x]; return q[x] = skim(x); } void solve(int n, int k, long long a, int s) { vector<int> v; __int128 sum = 0; for(int i = 1; i <= k; i++) { v.push_back(i); sum += get(i); if(sum > 2 * a)impossible(); } int l = 1, r = n, ind = n + 1; while(l <= r) { int m = (l + r) >> 1; if(get(m) > a)r = m - 1, ind = m; else l = m + 1; } if(ind < k)impossible(); if(ind < n + 1) { if(sum - get(k) + get(ind) <= 2 * a) { v.pop_back(); v.push_back(ind); answer(v); } } for(int i = max(k + 1, ind - k); i < ind; i++) { v.push_back(i); } l = 0, r = k; for(int i = 0; r < v.size(); i++) { if(a <= sum && sum <= a * 2)break; sum -= get(v[l]), l++; sum += get(v[r]), r++; } if(a <= sum && sum <= a * 2) { vector<int> ans; while(l < r)ans.push_back(v[l++]); answer(ans); } else impossible(); }

Compilation message (stderr)

books.cpp: In function 'void solve(int, int, long long int, int)':
books.cpp:52:22: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   52 |     for(int i = 0; r < v.size(); i++)
      |                    ~~^~~~~~~~~~
#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...