제출 #286556

#제출 시각아이디문제언어결과실행 시간메모리
286556__SIGSEGV__Mobile (BOI12_mobile)C++17
90 / 100
1022 ms35336 KiB
#include <bits/stdc++.h> using namespace std; #define rep(x,a) for(int x = 0; x < a; x++) #define REP(x,a,b) for(int x = a; x < b; x++) #define per(x,b) for(int x = b; x >= 0; x--) #define all(container) (container).begin(), container.end() #define rall(container) (container).rbegin(), container.rend() #define sz(container) (int) (container).size() #define pb push_back #define eb emplace_back #define fi first #define sc second using ll = long long; using pii = pair<int, int>; using pll = pair<ll, ll>; template<class T> bool smin(T &a, T b) { return a > b ? (a = b, true) : false; } template<class T> bool smax(T &a, T b) { return a < b ? (a = b, true) : false; } #ifdef LOCAL_DEFINE #include "DEBUG.hpp" #else #define debug(...) 0 #endif const double eps = 1e-7; int main(void) { int n; double last; scanf("%d%lf", &n, &last); vector<pair<double, double>> points(n); rep(i,n) scanf("%lf%lf", &points[i].fi, &points[i].sc); auto Can = [&](double dist) { double r = 0.0; rep(i,n) { double delta = sqrt(dist*dist-points[i].sc*points[i].sc); double L = points[i].fi-delta, R = points[i].fi+delta; if (L <= r) smax(r, R); } return (r >= last); }; double l = 0.0, r = 1e10; while (r-l > eps) { double mid = (r+l)/2.0; if (Can(mid)) r = mid; else l = mid; } printf("%.6lf\n", l); return 0; }

컴파일 시 표준 에러 (stderr) 메시지

mobile.cpp: In function 'int main()':
mobile.cpp:35:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   35 |     scanf("%d%lf", &n, &last);
      |     ~~~~~^~~~~~~~~~~~~~~~~~~~
mobile.cpp:37:19: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   37 |     rep(i,n) scanf("%lf%lf", &points[i].fi, &points[i].sc);
      |              ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
#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...