Submission #632538

#TimeUsernameProblemLanguageResultExecution timeMemory
632538AanjaneyBalloons (CEOI11_bal)C++17
10 / 100
134 ms1920 KiB
#include <bits/stdc++.h> #define ll long long #define ull unsigned long long #define MOD 1000000007 #define MODA 998244353 #define pb push_back #define sortv(v) sort(v.begin(), v.end()) #define sorta(A, N) sort(A, A + N) #define debug(x) cerr << #x << " is " << x; #define rep(i, a, N) for (ll i = a; i < N; i++) #define f first #define s second #define uniq(v) \ { \ sort(v.begin(), v.end()); \ v.erase(unique(v.begin(), v.end()), v.end()); \ } #define speed \ ios_base::sync_with_stdio(false); \ cin.tie(NULL); \ cout.tie(NULL); using namespace std; double radius(ll xi, ll xj, ll r) { double rad = (xi - xj) * (xi - xj); rad /= double(4 * r); return rad; } void solve(ll tcase) { ll n; ll INF = 1e9; double eps = 1e-4; cin >> n; stack<pair<ll, ll>> st; rep(i, 0, n) { ll x, r; cin >> x >> r; if (!st.empty()) cout << fixed << setprecision(3) << min(double(r), radius(st.top().f, x, st.top().s)) << "\n"; else cout << fixed << setprecision(3) << double(r) << "\n"; while (!st.empty() && radius(st.top().f, INF, st.top().s) >= radius(x, INF, r) + eps) st.pop(); if (st.empty()) st.push({x, r}); } } int main() { speed; ll t = 1; rep(i, 1, t + 1) solve(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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...