This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
// Source: https://usaco.guide/general/io
#include <bits/stdc++.h>
using namespace std;
#define ii pair<double, double>
#define fi first
#define fou(i, a, b) for (int i = a; i <= b; ++i)
#define se second
double ans[1000009];
// nối tâm của 2 đường tròn => cạnh huyền tam giác
// tìm độ dài đoạn thẳng từ tọa độ đường tròn a đến đường tròn b => cạnh đáy
// cạnh còn lại của tam giác sẽ được tính bằng cách lấy bán kính 2 hình trừ nhau
/**
|`
| `
|____`
*/
double cal(ii a, double b) {
double sum = (b - a.fi) * (b - a.fi * 1.00) / (4 * 1.00 * a.se);
return sum;
}
int main() {
int n; cin >> n;
stack<pair<double, double>> st;
fou(i, 1, n) {
double x, r; cin >> x >> r;
double kq = r;
while(!st.empty()) {
auto it = st.top();
double sum = cal(it, x);
kq = min(kq, sum);
if (kq >= it.se) {
st.pop();
continue;
} else break;
}
st.push({x, kq});
ans[i] = kq;
}
fou(i, 1, n) cout << fixed << setprecision(3) << ans[i] << "\n" ;
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |