Submission #82068

#TimeUsernameProblemLanguageResultExecution timeMemory
82068FutymyCloneMobile (BOI12_mobile)C++14
0 / 100
1087 ms132096 KiB
#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 (stderr)

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);
                                  ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~
#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...