문제
게임의 아웃복서 캐릭터는 필살기인 '럭키 스트레이트' 기술이 있습니다. 이 기술은 매우 강력한 대신에 게임 내에서 점수가 특정 조건을 만족할 때만 사용할 수 있습니다.
특정 조건이란 현재 캐릭터의 점수를 N이라고 할 때 자릿수를 기준으로 점수 N을 반으로 나누어 왼쪽 부분의 자릿수의 합과 오른쪽 부분의 자릿수의 합을 더한 값이 동일한 상황을 의미합니다.
예를 들어 현재 점수가 123,402이라면 왼쪾 부분의 각 자릿수의 합은 1 + 2 + 3, 오른쪽 부분의 각 자릿수의 합은 4 + 0 + 2이므로 두 합이 6으로 동일하여 럭키 스트레이트를 사용할 수 있습니다.
현재 점수 N이 주어지면 럭키 스트레이트를 사용할 수 있는 상태인지 아닌지를 알려주는 프로그램을 작성하세요.
입력 조건
첫째 줄에 점수 N이 정수로 주어집니다. (10 <= N <= 99,999,999) 단, 점수 N의 자릿수는 항상 짝수 형태로만 주어집니다. 예를 들어 자릿수가 5인 12,345와 같은 수는 입력으로 들어오지 않습니다.
출력 조건
첫째 줄에 럭키 스트레이트를 사용할 수 있다면 "LUCKY"를, 사용할 수 없다면 "READY"를 출력합니다.
입력 예시 1
123402
출력 예시 1
LUCKY
입력 예시 2
7755
출력 예시 2
READY
<내 풀이>
생각한대로 코드로 작성해서 쉽게 풀 수 있었다.
n = input() # 문자
length = len(n) # 문자의 길이
left = 0
right = 0
for i in range(length):
if i<length//2:
left += int(n[i])
else:
right += int(n[i])
if left == right:
print("LUCKY")
else:
print("READY")
<책 풀이>
n = input()
length = len(n) # 점수값의 총 자릿수
summary = 0
# 왼쪽 부분의 자릿수 합 더하기
for i in range(length // 2):
summary += int(n[i])
# 오른쪽 부분의 자릿수 합 빼기
for i in range(length // 2, length):
summary -= int(n[i])
# 왼쪽 부분과 오른쪽 부분의 자릿수 합이 동일한지 검사
if summary == 0:
print("LUCKY")
else:
print("READY")
'코딩 테스트' 카테고리의 다른 글
[이코테] 구현 문제 : Q 09. 문자열 압축 (0) | 2023.07.23 |
---|---|
[이코테] 구현 문제 : Q 08. 문자열 재정렬 (0) | 2023.07.20 |
[이코테] 그리디 문제 : Q 06. 무지의 먹방 라이브 (0) | 2023.07.19 |
[이코테] 그리디 문제 : Q 05. 볼링공 고르기 (0) | 2023.07.19 |
[이코테] 그리디 문제 : Q 04. 만들 수 없는 금액 (0) | 2023.07.11 |