Submission #649897

#TimeUsernameProblemLanguageResultExecution timeMemory
649897ymmBalloons (CEOI11_bal)C++17
20 / 100
212 ms4604 KiB
#include <bits/stdc++.h> #define Loop(x,l,r) for (ll x = (l); x < (ll)(r); ++x) #define LoopR(x,l,r) for (ll x = (r)-1; x >= (ll)(l); --x) typedef long long ll; typedef std::pair<int, int> pii; typedef std::pair<ll , ll > pll; using namespace std; typedef pair<double, double> pdd; struct obj { double st; pdd f; }; struct cmp_slope { bool operator()(const obj &x, const obj &y) const { return x.f.first < y.f.first; } }; struct cmp_st { bool operator()(const obj &x, const obj &y) const { return x.st > y.st; } }; set<obj, cmp_st> daaard; set<obj, cmp_slope> *by_slope = (set<obj, cmp_slope> *)&daaard; set<obj, cmp_st> *by_st = &daaard; double inter(pdd f, pdd g) { return (f.second - g.second) / (g.first - f.first); } double eval(pdd f, double x) { return f.first * x + f.second; } double get(double x) { auto it = by_st->upper_bound({x, {}}); return eval((--it)->f, x); } bool should_remove(pdd l, pdd m, pdd r) { double x = inter(l, r); double y0 = eval(m, x); double y1 = eval(l, x); return y0 >= y1; } void insert(pdd f) { auto it1 = by_slope->lower_bound({0, f}); auto it0 = it1; --it0; if (should_remove(it0->f, f, it1->f)) return; for (;;) { if (it0 == by_slope->begin()) break; auto it00 = it0; --it00; if (!should_remove(it00->f, it0->f, f)) break; by_slope->erase(it0); it0 = it00; } for (;;) { auto it11 = it1; ++it11; if (it11 == by_slope->end()) break; if (!should_remove(f, it1->f, it11->f)) break; by_slope->erase(it1); it1 = it11; } double st0 = inter(it0->f, f); double st1 = inter(f, it1->f); obj o0 = {st0, f}; obj o1 = {st1, it1->f}; by_slope->erase(it1); by_slope->insert(o0); by_slope->insert(o1); } void init() { obj o0 = {-1e18, {1e9, 1e18}}; obj o1 = {0, {-1e9, 1e18}}; *by_st = {o0, o1}; } pdd in() { ll x, y; cin >> x >> y; return {x, y}; } int main() { cin.tie(0) -> sync_with_stdio(false); cout << fixed << setprecision(3); init(); int n; cin >> n; Loop (i,0,n) { auto [x, r] = in(); r = sqrt(r); r = min(r, get(x)); cout << r*r << '\n'; insert({0.5/r, -x*0.5/r}); } }
#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...