[문제]
게임의 아웃복서 캐릭터는 필살기인 '럭키 스트레이트' 기술이 있습니다. 이 기술은 매우 강력한 대신에 게임 내에서
점수가 특정 조건을 만족할 때만 사용할 수 있습니다.
특정 조건이란 현재 캐릭터의 점수를 N이라고 할 때 자릿수를 기준으로 점수 N을 반으로 나누어 왼쪽 부분의 각
자릿수의 합과 오른쪽 부분의 각 자릿수의 합을 더한 값이 동일한 상황을 의미합니다.
예를 들어 현재 점수가 123,402라면 왼쪽 부분의 각 자릿수의 합은 1 + 2 + 3, 오른쪽 부분의 각 자릿수의 합은
4 + 0 + 2이므로 두 합이 6으로 동일하여 럭키 스트레이트를 사용할 수 있습니다.
현재 점수 N이 주어지면 럭키 스트레이트를 사용할 수 있는 상태인지 아닌지를 알려주는 프로그램을 작성하세요.
[입력 조건]
1. 첫째 줄에 점수 N이 정수로 주어집니다. (10 <= N <= 99,999,999) 단, 점수 N의 자릿수는 항상 짝수 형태로만
주어집니다. 예를 들어 자릿수가 5인 12,345와 같은 수는 입력으로 들어오지 않습니다.
[출력 조건]
첫째 줄에 럭키 스트레이트를 사용할 수 있다면 "LUCKY"를, 사용할 수 없다면 "READY"를 출력합니다.
<입력 예시 1>
123402
<출력 예시 1>
LUCKY
<입력 예시 2>
7755
<출력 예시2>
READY
[내 풀이]
n = input()
number = len(n) // 2
left_value = 0
for i in range(number) :
left_value += int(n[i])
right_value = 0
for i in range(number, len(n)) :
right_value += int(n[i])
if left_value == right_value :
print('LUCKY')
else :
print('READY')
1. n을 입력받고 n의 길이에 2를 나눈 몫을 number에 할당한다.
2. 반복문을 통해 점수 n을 자릿수를 기준으로 반으로 나누어 왼쪽 부분의 각 자릿수의 합과 오른쪽 부분의 각 자릿수의 합을 구한다.
3. 조건문을 통해 왼쪽 자릿수의 합과 오른쪽 자릿수의 합이 동일하다면 'LUCKY'를 출력하고 그렇지 않을 경우 'READY'를 출력한다.
출처
이것이 코딩 테스트다 with 파이썬 - 나동빈 저
'알고리즘 > 이코테 알고리즘 유형별 기출문제' 카테고리의 다른 글
[구현] 이코테 (파이썬) 뱀 풀이 (0) | 2021.12.17 |
---|---|
[구현] 이코테 (파이썬) 문자열 압축 풀이 (0) | 2021.12.13 |
[정렬] 이코테 (파이썬) 카드 정렬하기 풀이 (0) | 2021.12.06 |
[정렬] 이코테 (파이썬) 실패율 풀이 (0) | 2021.12.06 |
[정렬] 이코테 (파이썬) 안테나 풀이 (0) | 2021.12.06 |