Submission #696444

#TimeUsernameProblemLanguageResultExecution timeMemory
696444vjudge1Mobile (BOI12_mobile)C++14
100 / 100
753 ms55252 KiB
#include "bits/stdc++.h" using namespace std; const long long precision = 1e4; // TO not to deal with double/float precision problems // UPD: Didn't use it instaed used double const int MAXN = 1e6+5; //long long stations[MAXN][2]; vector < vector<double> > stations; int main() { ios_base::sync_with_stdio(0); cin.tie(0); double n, length; cin >> n >> length; //length *= precision; for(int i = 1; i <= n; i++) { double x, y; cin >> x >> y; //x *= precision; //y *= precision; if(stations.size() == 0 || (stations.back())[0] != x) stations.push_back({x, y}); else { vector<double> elem = stations.back(); if(abs(elem[1]) > abs(y)) { stations.pop_back(); stations.push_back({x, y}); } } /*cin >> stations[i][0] >> stations[i][1]; stations[i][0] *= precision; stations[i][1] *= precision;*/ } double l = 0, r = 2.3e9, ans = 2.3e9; // Max distance will be 3e9 as we can we have 2e9 vertical and 2e9 horizontal distance so according to the pythagoran sqrt(2e9^2 + 2e9^2) = 2e9 * sqrt(2) while(r - l >= 0.0001) { double m = (l + r) / 2.0000; double left = length, right = 0; for(int i = 0; i < stations.size(); i++) { double x = stations[i][0], y = stations[i][1]; //cout << x << " " << y << "\n"; if(abs(y) > m) continue; double horizontal = sqrt((m * m) - (y * y)); //cout << x << " " << y << " " << m << " " << horizontal << "\n"; if(x <= 0) { if(x + horizontal >= 0) { left = 0, right = max(right, (double) (x + horizontal)); } } else { double templeft = max((double)0.0000, (double)(x - horizontal)); double tempright = min(length, (double)(x + horizontal)); if(templeft <= right) { left = min(left, max((double)0.0000, templeft)); right = max(right, min(length, tempright)); } } } if(left <= 0 && right >= length) { ans = m; r = m - 0.0001; } else l = m + 0.0001; } cout << fixed << setprecision(10) << ans << "\n"; }

Compilation message (stderr)

mobile.cpp: In function 'int main()':
mobile.cpp:48:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<double> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   48 |   for(int i = 0; i < stations.size(); i++)
      |                  ~~^~~~~~~~~~~~~~~~~
#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...