알고리즘 연습/수학, 정수론, 기하

[🥉3 / 백준 3034 / 파이썬] 앵그리 창영

김세진 2022. 5. 12. 09:45
반응형

 

 

3034번: 앵그리 창영

첫째 줄에 던진 성냥의 개수 N과 박스의 가로 크기 W와 세로 크기 H가 주어진다. (1 ≤ N ≤ 50, 1 ≤ W, H ≤ 100) 다음 N개 줄에는 성냥의 길이가 주어진다. 길이는 1보다 크거나 같고 1000보다 작거나

www.acmicpc.net

 

문제

창영이는 화가나서 성냥을 바닥에 던졌다.

상근이는 바닥이 더러워진 것을 보고 창영이를 매우 혼냈다.

강산이는 근처에서 박스를 발견했다.

상덕이는 강산이가 발견한 박스를 상근이에게 주었다.

상근이는 박스에 던진 성냥을 모두 담아오라고 시켰다.

하지만, 박스에 들어가지 않는 성냥도 있다.

이런 성냥은 박스에 담지 않고 희원이에게 줄 것이다.

성냥이 박스에 들어가려면, 박스의 밑면에 성냥이 모두 닿아야 한다.

박스의 크기와 성냥의 길이가 주어졌을 때, 성냥이 박스에 들어갈 수 있는지 없는지를 구하는 프로그램을 작성하시오. 창영이는 성냥을 하나씩 검사한다.

입력

첫째 줄에 던진 성냥의 개수 N과 박스의 가로 크기 W와 세로 크기 H가 주어진다. (1 ≤ N ≤ 50, 1 ≤ W, H ≤ 100)

다음 N개 줄에는 성냥의 길이가 주어진다. 길이는 1보다 크거나 같고 1000보다 작거나 같은 자연수이다. 

출력

입력으로 주어지는 각각의 성냥에 대해서, 박스안에 들어갈 수 있으면 "DA" 없으면 "NE"를 출력한다.

 

예제 입력 1

5 3 4
3
4
5
6
7

예제 출력 1

DA
DA
DA
NE
NE

예제 입력 2

2 12 17
21
20

예제 출력 2

NE
DA

 

풀이

 

박스에 넣을 수 있는 성냥의 최대 길이는 박스의 대각선 길이이다.

따라서 피타고라스의 정리로 빗변의 길이를 구해 이 길이보다 작거나 같은 성냥은 DA, 아니면 NE를 출력한다.

 

import sys
input = sys.stdin.readline

n,w,h = map(int,input().split())
d = (w**2+h**2)**0.5
for _ in range(n):
    print('DA' if d >= int(input()) else 'NE')
반응형