※ 글쓴이는 취미로 코딩을 익혀보는 사람이라 정확하지 않은 내용을 담고 있을 수 있다 ※
이번에 볼 문제는 백준 22421번 문제인 Koto Municipal Subway이다.
문제는 아래 링크를 확인하자.
https://www.acmicpc.net/problem/22421
22421번: Koto Municipal Subway
Koto市は,下図のように,道路が碁盤の目状である有名な街である. 南北に伸びる道と東西に伸びる道は,それぞれ1kmの間隔で並んでいる. Koto市の最も南西の交差点にあるKoto駅を (0, 0) とし
www.acmicpc.net
각 좌표의 절댓값이 합이 D인 각 격자점들에 대해 이 점과 원점 사이의 직선거리와 E의 차의 최솟값을 찾는 문제이다.
반복문을 이용해 살필 필요가 있는 모든 경우에 대해 위의 값을 조사하는 것으로 문제를 해결하자.
아래는 제출한 소스코드이다.
#include <iostream>
#include <cmath>
using namespace std;
typedef long double ld;
int D, E;
int main() {
ios::sync_with_stdio(0);
cin.tie(0);
cout << fixed;
cout.precision(10);
cin >> D >> E;
while (D) {
ld ans = 1000000007;
int x = 0, y = D;
while (x <= y) {
ans = min(ans, abs(hypot((ld)x, (ld)y) - E));
x++, y--;
}
cout << ans << '\n';
cin >> D >> E;
}
}
728x90
'BOJ' 카테고리의 다른 글
[BOJ 26547 // C++] Square (0) | 2022.12.21 |
---|---|
[BOJ 26510 // C++] V for Vendetta (0) | 2022.12.21 |
[BOJ 26509 // C++] Triangle (0) | 2022.12.21 |
[BOJ 5356 // C++] Triangles (0) | 2022.12.21 |
[BOJ 26534 // C++] Goats (0) | 2022.12.21 |