답안 #82068

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
82068 2018-10-29T02:12:00 Z FutymyClone Mobile (BOI12_mobile) C++14
0 / 100
1000 ms 132096 KB
#include <bits/stdc++.h>

using namespace std;

const int N = 1e6 + 5;
const double eps = 1e-8;

struct Point {
    int x, y;
} a[N];

int n, m;

bool cmp (pair <double, double> p1, pair <double, double> p2) {
    return p1.second < p2.second;
}

bool check (double mid) {
    vector <pair <double, double> > vec;
    for (int i = 1; i <= n; i++) {
        //(a[i].x - x)^2 + a[i].y^2 = mid^2
        double cur = mid * mid - a[i].y * a[i].y;
        double lx = -sqrt(cur) + a[i].x;
        double rx = sqrt(cur) + a[i].x;
        vec.push_back({lx, rx});
    }

    sort(vec.begin(), vec.end(), cmp);
    double pt = vec[0].second;
    for (int i = 1; i < vec.size(); i++) {
        if (vec[i].first > pt) return false;
        pt = max(pt, vec[i].second);
    }

    return true;
}

int main(){
    scanf("%d %d", &n, &m);
    for (int i = 1; i <= n; i++) scanf("%d %d", &a[i].x, &a[i].y);

    double l = 0, r = m;
    while (abs(r - l) > eps) {
        double mid = (l + r) / 2;
        if (check(mid)) r = mid;
        else l = mid + eps;
    }

    cout << fixed << setprecision(10) << l;
    return 0;
}

Compilation message

mobile.cpp: In function 'bool check(double)':
mobile.cpp:30:23: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     for (int i = 1; i < vec.size(); i++) {
                     ~~^~~~~~~~~~~~
mobile.cpp: In function 'int main()':
mobile.cpp:39:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     scanf("%d %d", &n, &m);
     ~~~~~^~~~~~~~~~~~~~~~~
mobile.cpp:40:39: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     for (int i = 1; i <= n; i++) scanf("%d %d", &a[i].x, &a[i].y);
                                  ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Incorrect 2 ms 256 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 2 ms 376 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 8 ms 712 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 16 ms 804 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 23 ms 868 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 23 ms 976 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 343 ms 5428 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 296 ms 6336 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 404 ms 7328 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 666 ms 9144 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 588 ms 10644 KB Output is correct
2 Incorrect 553 ms 12088 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1065 ms 31928 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1078 ms 40256 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1067 ms 55756 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1078 ms 65792 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1087 ms 74072 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1077 ms 85484 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1067 ms 94940 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1066 ms 108144 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1070 ms 121612 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1085 ms 132096 KB Time limit exceeded
2 Halted 0 ms 0 KB -