BOJ 3034 - 앵그리 창영 (Python3)

2022. 11. 15. 23:24Bronze/Bronze III

초기에 번역된 문제들 중에는 번역 질이 안 좋은 것을 넘어 기본적인 띄어쓰기도 제대로 안 되어 있는 경우가 가끔 있다.

그와 별개로 간단한 조건문 테스트와 삼항연산자에 대해 좋은 연습이 될 것 같아서 가져 왔다.

그래서 대체 창영은 누구인가?

 

그럼 본격적으로 풀이에 돌입해 보자.


문제

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

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

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

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

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

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

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

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

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

 

입력

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

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

 

예제 입력)

# 예제 입력 1
5 3 4
3
4
5
6
7

# 예제 입력 2
2 12 17
21 20

 

출력

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

 

예제 출력)

# 예제 출력 1
DA
DA
DA
NE
NE

# 예제 출력 2
NE
DA

 


내 코드

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

 

성냥의 길이가 성냥 박스 밑면의 대각선보다 길다면 들어갈 수가 없을 것이다.

따라서 처음 성냥의 갯수와 박스 밑면의 수치를 입력한 다음, 삼항연산자를 이용하여서 성냥의 길이 제곱이 가로 제곱+세로 제곱보다 크다면 NE를 출력하도록 프로그램을 짜면 된다.

크게 어려울 것 없는, 피타고라스 정리와 반복문 문제이다.

줄 수를 줄이려면 삼항연산자를 적극 활용하는 편이 좋겠다.

 

이로서 3034번의 풀이를 마친다.

그럼, 오늘도 당신의 코딩 실력이 상승하기를.

 

728x90