728x90
반응형
럭키 스트레이트 (18406번)
시간 제한 : 1초 메모리 제한 : 256 MB
문제
어떤 게임의 아웃복서 캐릭터에게는 럭키 스트레이트라는 기술이 존재한다. 이 기술은 매우 강력한 대신에 항상 사용할 수는 없으며, 현재 게임 내에서 점수가 특정 조건을 만족할 때만 사용할 수 있다.
특정 조건이란 현재 캐릭터의 점수를 N이라고 할 때 점수 N을 자릿수를 기준으로 반으로 나누어 왼쪽 부분의 각 자릿수의 합과 오른쪽 부분의 각 자릿수의 합을 더한 값이 동일한 상황을 의미한다. 예를 들어 현재 점수가 123,402라면 왼쪽 부분의 각 자릿수의 합은 1+2+3, 오른쪽 부분의 각 자릿수의 합은 4+0+2이므로 두 합이 6으로 동일하여 럭키 스트레이트를 사용할 수 있다.
현재 점수 N이 주어졌을 때, 럭키 스트레이트를 사용할 수 있는 상태인지 아닌지를 알려주는 프로그램을 작성하시오. 럭키 스트레이트를 사용할 수 있다면 "LUCKY"를, 사용할 수 없다면 "READY"라는 단어를 출력한다. 또한 점수 N의 자릿수는 항상 짝수 형태로만 주어진다. 예를 들어 자릿수가 5인 12,345와 같은 수는 입력으로 들어오지 않는다.
입력
첫째 줄에 점수 N이 정수로 주어진다. (10 ≤ N ≤ 99,999,999) 단, 점수 N의 자릿수는 항상 짝수 형태로만 주어진다.
출력
첫째 줄에 럭키 스트레이트를 사용할 수 있다면 "LUCKY"를, 사용할 수 없다면 "READY"라는 단어를 출력한다.
예제 입력
123402
예제 출력
LUCKY
해답
score = input()
half_length = len(score) // 2
front = score[0:half_length]
back = score[half_length:]
front_sum, back_sum = 0, 0
for i in range(len(front)):
front_sum = front_sum + int(front[i])
for i in range(len(back)):
back_sum = back_sum + int(back[i])
if front_sum == back_sum:
print("LUCKY")
else:
print("READY")
풀이
입력값을 score 변수에 저장한 뒤, 앞부분을 front 뒷부분을 back에 문자열 형태로 저장합니다.
그런 뒤 front의 합을 front_sum 변수에 int형 변환으로 저장하고, back_sum에도 마찬가지로 저장해줍니다.
마지막으로 if 비교문을 사용하여 조건에 맞게 출력해줍니다.
728x90
반응형
'알고리즘 (Python) > 백준' 카테고리의 다른 글
[백준] 정렬 알고리즘 - 국영수 (10825번) #파이썬#python (0) | 2023.03.24 |
---|---|
[백준] 그리디 알고리즘 - 슬라임 합치기 (14241번) #파이썬#python (0) | 2020.10.08 |
[백준] 그리디 알고리즘 - 폴리오미노 (1343번) #파이썬 #python (0) | 2020.09.19 |
[백준] 그리디 알고리즘 - 컵홀더 (2810번) #파이썬 #python (0) | 2020.09.19 |
[백준] 그리디 알고리즘 - 설탕 배달 (2839번) #파이썬 #python (0) | 2020.09.19 |