Submission #1285703

#TimeUsernameProblemLanguageResultExecution timeMemory
1285703thanhliem40Balloons (CEOI11_bal)C++20
100 / 100
88 ms6680 KiB
#include<bits/stdc++.h> #define ll long long using namespace std; ll n; ll x[200001]; double r[200001]; double ans[200001]; stack<pair<double,double>> st; double cal(double ir,ll ix,ll jx) { return (double)((jx-ix)*(jx-ix))/(4*ir); } int main() { ios_base::sync_with_stdio(0); cin.tie(0); //freopen("BALLOONS.INP","r",stdin); //freopen("BALLOONS.OUT","w",stdout); cin >> n; for(ll i=1;i<=n;i++) { cin >> x[i] >> r[i]; } for(ll i=1;i<=n;i++) { double res=r[i]; while(!st.empty()) { res=min(res,cal(st.top().second,st.top().first,x[i])); if(res>=st.top().second) { st.pop(); continue; } else { break; } } ans[i]=res; st.push({x[i],ans[i]}); } for(ll i=1;i<=n;i++) { cout << setprecision(3) << fixed << ans[i] << '\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...