문제
창영이는 화가나서 성냥을 바닥에 던졌다.
상근이는 바닥이 더러워진 것을 보고 창영이를 매우 혼냈다.
강산이는 근처에서 박스를 발견했다.
상덕이는 강산이가 발견한 박스를 상근이에게 주었다.
상근이는 박스에 던진 성냥을 모두 담아오라고 시켰다.
하지만, 박스에 들어가지 않는 성냥도 있다.
이런 성냥은 박스에 담지 않고 희원이에게 줄 것이다.
성냥이 박스에 들어가려면, 박스의 밑면에 성냥이 모두 닿아야 한다.
박스의 크기와 성냥의 길이가 주어졌을 때, 성냥이 박스에 들어갈 수 있는지 없는지를 구하는 프로그램을 작성하시오. 창영이는 성냥을 하나씩 검사한다.
입력
첫째 줄에 던진 성냥의 개수 N과 박스의 가로 크기 W와 세로 크기 H가 주어진다. (1 ≤ N ≤ 50, 1 ≤ W, H ≤ 100)
다음 N개 줄에는 성냥의 길이가 주어진다. 길이는 1보다 크거나 같고 1000보다 작거나 같은 자연수이다.
출력
입력으로 주어지는 각각의 성냥에 대해서, 박스안에 들어갈 수 있으면 “DA” 없으면 “NE”를 출력한다.
출력 예제
DA
NE
DA

요구사항
- 피타고라스의 정리를 이해해야 한다.
설명
성냥을 박스에 넣을 때 가로, 세로는 물론 대각선으로도 넣을 수 있음을 이해하고 피타고라스 정리를 파이썬으로 구현할 수 있어야 한다.
정답 코드
# 성냥 개수, 박스의 가로 크기, 세로 크기를 입력받는다.
n, w, h = list(map(int, input().split()))
for _ in range(n):
# 성냥의 길이를 입력받는다.
match_len = int(input())
# 성냥의 길이가 박스의 가로나 세로 크기보다 작으면 DA를 출력한다.
if match_len <= w or match_len <= h:
print("DA")
# 피타고라스 정리에 따라 성냥의 길이가 박스의 빗변의 길이보다 작으면 DA를 출력한다.
elif match_len**2 <= w**2 + h**2:
print("DA")
# 그 외 모두 NE를 출력한다.
else:
print("NE")