※ 글쓴이는 취미로 코딩을 익혀보는 사람이라 정확하지 않은 내용을 담고 있을 수 있다 ※

 

이번에 볼 문제는 백준 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

+ Recent posts