Submission #592046

#TimeUsernameProblemLanguageResultExecution timeMemory
592046tutisUplifting Excursion (BOI22_vault)C++17
0 / 100
1869 ms1528 KiB
/*input 1 5 0 0 6 */ #pragma GCC optimize ("O3") #pragma GCC target("avx,avx2,fma") #include <bits/stdc++.h> #include <ext/pb_ds/assoc_container.hpp> using namespace std; using namespace __gnu_pbds; template <typename T> using oset = tree<T, null_type, less<T>, rb_tree_tag, tree_order_statistics_node_update>; using ll = long long; using ull = unsigned long long; using ld = long double; int main() { ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0); int M; ll L; cin >> M >> L; ll A[2 * M + 1]; for (int i = 0; i <= 2 * M; i++) cin >> A[i]; L = -L; ll cnt = 0; for (int l = -M; l <= M; l++) { L += l * A[l + M]; cnt += A[l + M]; } map<ll, ll>D; D[0] = 0; ll del = 100; for (int v = M; v >= 1; v--) for (int l : {v, -v}) { map<ll, ll>D_; for (pair<ll, ll>v : D) { ll k = (L - v.first) / l; ll lo = max(0ll, k - del); ll hi = min(k + del, A[l + M]); for (ll c = lo; c <= hi; c++) { ll v_ = v.first + l * c; ll c_ = v.second + c; if (D_.count(v_) == 0) D_[v_] = c_; else D_[v_] = min(D_[v_], c_); } } D = D_; } if (D.count(L)) cout << cnt - D[L] << "\n"; else cout << "impossible\n"; }
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...