문제 링크: https://www.acmicpc.net/problem/4153
4153번: 직각삼각형
입력은 여러개의 테스트케이스로 주어지며 마지막줄에는 0 0 0이 입력된다. 각 테스트케이스는 모두 30,000보다 작은 양의 정수로 주어지며, 각 입력은 변의 길이를 의미한다.
www.acmicpc.net
문제
과거 이집트인들은 각 변들의 길이가 3, 4, 5인 삼각형이 직각 삼각형인것을 알아냈다. 주어진 세변의 길이로 삼각형이 직각인지 아닌지 구분하시오.
입력
입력은 여러개의 테스트케이스로 주어지며 마지막줄에는 0 0 0이 입력된다. 각 테스트케이스는 모두 30,000보다 작은 양의 정수로 주어지며, 각 입력은 변의 길이를 의미한다.
출력
각 입력에 대해 직각 삼각형이 맞다면 "right", 아니라면 "wrong"을 출력한다.
코드
while True:
xyz = list(map(int, input().split()))
if sum(xyz) == 0:
break
max_ = max(xyz)
xyz.remove(max_)
if max_**2 == xyz[0]**2 + xyz[1]**2:
print("right")
else:
print("wrong")
문제 요약
입력받은 수들을 통해 피타고라스의 정리(c^2 = a^2 + b^2)를 통해 직각삼각형이 가능한지 아닌지 확인하는 문제이다.
코드 설명
- 입력받는 수들을 한줄 씩 입력받아 mapping 후 xyz 변수에 리스트로 할당한다.
- 입력받은 수들이 0일 경우 while문을 중지한다.
while True: xyz = list(map(int, input().split())) if sum(xyz) == 0: break
- 입력받은 수가 0, 0, 0이 아닐 경우, xyz의 리스트에서 가장 큰 수를 max_ 변수에 할당하고, xyz 리스트에서 max_를 제거한다.
- 피타고라스의 정리를 이용하여 가장 긴변인 max_2의 제곱이 나머지 두 길이 각각의 제곱과 일치할 경우 right을 출력, 아닐 경우 wrong을 출력한다.
max_ = max(xyz) xyz.remove(max_) if max_**2 == xyz[0]**2 + xyz[1]**2: print("right") else: print("wrong")
반응형
댓글