본문 바로가기

[C언어] 백준온라인/* 수학 2

[C 언어] 백준 3053. 택시 기하학


3053. 택시 기하학 (누르면 해당 문제로 이동)

유클리드 기하학과 택시 기하학에 대한 문제

 

제약사항)

시간 : 1 초

메모리 : 128 MB

 

문제)

19세기 독일 수학자 헤르만 민코프스키는 비유클리드 기하학 중 택시 기하학을 고안했다.

택시 기하학에서 두 점 T1(x1, y1), T2(x2, y2) 사이의 거리는 다음과 같이 구할 수 있다.

D(T1, T2) = |x1-x2| + |y1-y2|

 

두 점 사이의 거리를 제외한 나머지 정의는 유클리드 기하학에서의 정의와 같다.

따라서 택시 기하학에서 원의 정의는 유클리드 기하학에서 원의 정의와 같다.

원 : 평면 상의 어떤 점에서 거리가 일정한 점들의 집합

 

반지름 R이 주어졌을 때, 유클리드 기하학에서 원의 넓이와 택시 기하학에서 원의 넓이를 구하는 프로그램을 작성하시오.

 

입력)

첫째 줄에 반지름 R이 주어진다. R은 10,000보다 작거나 같은 자연수이다.

 

출력)

첫째 줄에는 유클리드 기하학에서 반지름이 R인 원의 넓이를, 둘째 줄에는 택시 기하학에서 반지름이 R인 원의 넓이를 출력한다.

정답과의 오차는 0.0001까지 허용한다.

 

입출력 예제

입력 출력
1 3.141593
2.000000

 


 

풀이 순서)

유클리드 기하학과 택시 기하학에서 정의를 잘 생각해보면 쉬운 문제입니다.

1. 유클리드 기하학에서 원의 넓이 : pie*R^2

2. 택시 기하학에서 원의 넓이 : 2*R^2

     : 택시 기하학에서 원은 마름모 형태가 되므로 위 식으로 원의 넓이를 구할 수 있습니다.

 


 

소스코드 및 결과 (C)

#include <stdio.h>

#define PI 3.14159265358979

int main() {
	int R;

	scanf("%d", &R);

	printf("%.6f\n", PI*R*R);
	printf("%.6f\n", 2.0*R*R);

	return 0;
}

 

메모리 : 1112 KB

시간 : 0 ms

코드길이 : 158 B