난이도 | 풀이 시간 | 시간 제한 | 메모리 제한 |
---|---|---|---|
1 | 30분 | 1초 | 256MB |
게임의 아웃복서 캐릭터는 필살기인 '럭키 스트레이트' 기술이 있습니다. 이 기술은 매우 강력한 대신에 게임 내에서 점수가 특정 조건을 만족할 때만 사용할 수 있습니다.
특정 조건이란 현재 캐릭터의 점수를 N이라고 할 때 자릿수를 기준으로 점수 N을 반으로 나누어 왼쪽 부분의 각 자릿수의 합과 오른쪽 부분의 각 자릿수의 합을 더한 값이 동일한 상황을 의미합니다.
예를 들어 현재 점수가 123,402라면 왼쪽 부분의 각 자릿수의 합은 1 + 2 + 3, 오른쪽 부분의 각 자릿수의 합은 4 + 0 + 2이므로 두 합이 6으로 동일하여 럭키 스트레이트를 사용할 수 있습니다.
현재 점수 N이 주어지면 럭키 스트레이트를 사용할 수 있는 상태인지 아닌지를 알려주는 프로그램을 작성하세요.
123402
LUCKY
7755
READY
function solution(N) {
const number = String(N);
let sum1 = 0, sum2 = 0;
for (let i = 0; i < number.length / 2; i++) {
sum1 += Number(number[i]);
}
for (let i = number.length / 2; i < number.length; i++) {
sum2 += Number(number[i]);
}
if (sum1 === sum2) {
console.log('LUCKY');
} else {
console.log('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")
각각 합계를 구해 같은 지로 비교했는데, 더한 후 빼서 0이 된다면 같은 값이라는 것을 이용해 문제 해결을 할 수 있다는 것을 알게 되었다.