Submission #1270274

#TimeUsernameProblemLanguageResultExecution timeMemory
1270274os_bein_lagginMobile (BOI12_mobile)C++20
0 / 100
276 ms16016 KiB
#include <bits/stdc++.h>
using namespace std;

struct Interval {
    double l, r;
};

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    int N;
    long long L;
    cin >> N >> L;

    vector<pair<long long, long long> > stations(N);
    for (int i = 0; i < N; i++) {
        cin >> stations[i].first >> stations[i].second;
    }

    auto canCover = [&](double R) -> bool {
        double covered = 0.0;

        for (int i = 0; i < N && covered < L; i++) {
            long long x = stations[i].first;
            long long y = stations[i].second;

            if (1.0 * y * y > R * R) continue; // cannot touch highway

            double dx = sqrt(R * R - 1.0 * y * y);
            double left = max(0.0, (double)x - dx);
            double right = min((double)L, (double)x + dx);

            if (left > covered + 1e-9) return false; // gap
            covered = max(covered, right);
        }

        return covered >= L;
    };

    double lo = 0.0, hi = 2e9; // upper bound big enough
    for (int it = 0; it < 60; it++) { // binary search precision
        double mid = (lo + hi) / 2.0;
        if (canCover(mid)) hi = mid;
        else lo = mid;
    }

    cout << fixed << setprecision(6) << hi << "\n";
    return 0;
}
#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...
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...