알고리즘/백준

백준 18406번 - 럭키 스트레이트 / Python

Hwisaek 2021. 8. 12. 09:16
반응형

문제: https://www.acmicpc.net/problem/18406

 

18406번: 럭키 스트레이트

첫째 줄에 점수 N이 정수로 주어진다. (10 ≤ N ≤ 99,999,999) 단, 점수 N의 자릿수는 항상 짝수 형태로만 주어진다.

www.acmicpc.net

문제 설명

더보기

문제

어떤 게임의 아웃복서 캐릭터에게는 럭키 스트레이트라는 기술이 존재한다. 이 기술은 매우 강력한 대신에 항상 사용할 수는 없으며, 현재 게임 내에서 점수가 특정 조건을 만족할 때만 사용할 수 있다.

특정 조건이란 현재 캐릭터의 점수를 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"라는 단어를 출력한다.


정답

def solution(n):
    n = list(map(int, n))
    length = len(n)
    if sum(n[:length // 2]) == sum(n[length // 2:]):
        return "LUCKY"
    return "READY"

n = input()
print(solution(n))

 


풀이

더보기
def solution(n):
    n = list(map(int, n))
    length = len(n)
    if sum(n[:length // 2]) == sum(n[length // 2:]):
        return "LUCKY"
    return "READY"

n = input()
print(solution(n))

  문자열이 각 절반의 합이 같으면 "LUCKY", 다르면 "READY"를 출력하는 문제입니다. 

 

 문자열로 들어온 데이터를 정수 배열로 변경한 다음 반씩 나눠서 sum()을 사용하면 됩니다.

반응형

'알고리즘 > 백준' 카테고리의 다른 글

백준 2475번 - 검증수 / Python  (0) 2021.08.12
백준 7287번 - 등록 / Python  (0) 2021.08.12
백준 2558번 - A+B - 2 / Python  (0) 2021.08.12
백준 10773번 - 제로 / Python  (0) 2021.08.01
백준 2178번 - 미로탐색 / Java  (0) 2021.07.30