이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#define ONLINE_JUDGE
#include <cstdio>
#include <cmath>
#include <vector>
/*#include <windows.h>
const HANDLE handle = GetStdHandle(STD_OUTPUT_HANDLE);
inline void scta(const int &clr) { SetConsoleTextAttribute(handle, clr); }*/
using namespace std;
vector <pair <int, int>> points;
vector <pair <double, double>> intervals;
double radius;
int n, len, x, y, i;
double l, r = 2e9, m;
int main() {
scanf("%d%d%d%d", &n, &len, &x, &y);
points.push_back({x, abs(y)});
while (--n) {
scanf("%d%d", &x, &y);
if (points.back().first == x) {
if (y < 0) {
points.back().second = -y;
}
}
else points.push_back({x, y});
}
while (r - l > 1e-8) {
m = (l + r) / 2.0;
intervals.clear();
intervals.push_back({0.0, len});
/*scta(7);
printf("l = %lf, r = %lf, m = %lf\n", l, r, m);*/
for (auto &point : points) {
x = point.first;
radius = sqrt(m * m - double(point.second) * double(point.second));
/*scta(15);
printf(" Intervals =");
scta(14);
for (auto &in : intervals) {
printf(" (%lf, %lf)", in.first, in.second);
}
scta(15);
printf("\n place = %d, radius = %lf\n", x, radius);*/
for (i = intervals.size() - 1; i >= 0; i--) {
if (x - radius <= intervals[i].first && intervals[i].second <= x + radius) {
// scta(10); printf(" Entire interval is contained\n");
intervals.erase(intervals.begin() + i);
}
else if (x + radius <= intervals[i].first || intervals[i].second <= x - radius) {
// scta(12); printf(" None of the interval is contained\n");
}
else if (x - radius <= intervals[i].first && x + radius <= intervals[i].second) {
// scta(9); printf(" The left part of the interval is contained\n");
intervals[i].first = x + radius;
}
else if (intervals[i].first <= x - radius && intervals[i].second <= x + radius) {
// scta(13); printf(" The right part of the interval is contained\n");
intervals[i].second = x - radius;
}
else {
// scta(11); printf(" The interval has to be split into two\n");
intervals.push_back({x + radius, intervals[i].second});
intervals[i].second = x - radius;
}
}
if (intervals.empty()) break;
}
if (intervals.empty()) r = m; else l = m;
}
printf("%lf\n", l);
return 0;
}
컴파일 시 표준 에러 (stderr) 메시지
mobile.cpp: In function 'int main()':
mobile.cpp:15:10: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
15 | scanf("%d%d%d%d", &n, &len, &x, &y);
| ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
mobile.cpp:18:14: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
18 | scanf("%d%d", &x, &y);
| ~~~~~^~~~~~~~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |