제출 #445962

#제출 시각아이디문제언어결과실행 시간메모리
445962Qw3rTyMobile (BOI12_mobile)C++11
50 / 100
1094 ms31544 KiB
#pragma GCC optimize(2) #pragma GCC optimize(3) #pragma GCC optimize("Ofast") #include <bits/stdc++.h> #define int long long #define db double #define delta 1e-5 #define INF 1e9+5 #define pi pair<int,int> #define pb pair<db,db> #define fi first #define se second using namespace std; const int maxN = 1e6+5; int N,L; pi tower[maxN]; pb inter[maxN]; //intersections bool cmp(pb a, pb b){ if(abs(a.fi - b.fi) < delta)return a.se < b.se; return a.fi < b.fi; } bool works(db r){ //Reset inter array for(int i = 1; i <= N; ++i){ inter[i].fi = 0; inter[i].se = -1; } for(int i = 1; i <= N; ++i) { //Can't reach any point on the highway if (abs(r) < abs(tower[i].se))continue; inter[i].fi = tower[i].fi - sqrt(r*r - tower[i].se*tower[i].se); inter[i].se = tower[i].fi + sqrt(r*r - tower[i].se*tower[i].se); inter[i].fi = (inter[i].fi < 0)?0:inter[i].fi; inter[i].se = (inter[i].se > L)?L:inter[i].se; } sort(inter+1,inter+N+1,cmp); db a = 0; db b = 0; if(abs(inter[1].fi) > delta)return false; for(int i = 1; i <= N; ++i){ //Invalid intersections if(inter[i].fi > inter[i].se)continue; //Merge intervals if(inter[i].fi <= b)b = (inter[i].se > b)?inter[i].se:b; else return false; if(abs(b-L) < delta)return true; } return false; } signed main(){ ios_base::sync_with_stdio(false); cin.tie(0); //freopen("../test.in","r",stdin); cin >> N >> L; for(int i = 1; i <= N; ++i)cin >> tower[i].fi >> tower[i].se; db low = 1; db high = 2e9; while(abs(high-low) > delta){ db mid = (low+high)/2; if(works(mid))high = mid; else low = mid + delta; } cout << setprecision(12) << low << '\n'; return 0; }

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

mobile.cpp: In function 'bool works(double)':
mobile.cpp:41:5: warning: unused variable 'a' [-Wunused-variable]
   41 |  db a = 0; db b = 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...