BAEKJOON #18406(구현)

nathan·2021년 7월 7일
0

알고리즘문제

목록 보기
11/102

럭키 스트레이트

출처 : 백준 #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"라는 단어를 출력한다.


입출력 예시

예제 입력 1

123402

예제 출력 1

LUCKY


예제 입력 2

7755

예제 출력 2

READY


풀이

풀이 설명

  • 우선 int로 받게된 이유는 str 그대로 stdin.readline()으로 받아버리게 되면 마지막에 입력할 때 누르는 엔터키 때문에 \n이 함께 n에 들어가게 되기 때문이다.

    • 실험해보니 input()\n이 함께 들어가지는 않았다.
  • 따라서 int 값으로 우선 받아 str()로 형 변환을 해주었다.

python code

# 백준 18406번
from sys import stdin

def solution(n):
    string = str(n)
    mid = len(string)//2
    num_1 = string[:mid]
    num_2 = string[mid:]
    result_1 = 0
    result_2 = 0

    for i in num_1:
        result_1 += int(i)

    for j in num_2:
        result_2 += int(j)
    
    if result_1 == result_2:
        return "LUCKY"
    else:
        return "READY"


n = int(stdin.readline())
print(solution(n))
profile
나는 날마다 모든 면에서 점점 더 나아지고 있다.

0개의 댓글