본문 바로가기
Algorithm/Python

[백준 18406번] 럭키 스트레이트

by _sweep 2022. 3. 9.

문제 링크 >> https://www.acmicpc.net/problem/18406

 

 

📋 문제

어떤 게임의 아웃복서 캐릭터에게는 럭키 스트레이트라는 기술이 존재한다.

이 기술은 매우 강력한 대신에 항상 사용할 수는 없으며, 현재 게임 내에서 점수가 특정 조건을 만족할 때만 사용할 수 있다.

 

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

 

 

📝 풀이

n = input()
num1, num2 = sum(map(int,n[:len(n)//2])), sum(map(int, n[len(n)//2:]))
print("LUCKY" if num1 == num2 else "READY")

 

단순한 문자열 자르기 문제였다.

절반을 기준으로 자른 뒤 map을 이용해 정수형으로 바꾸고 sum으로 합을 구했다.

그리고 이들을 각각 num1과 num2에 담고 값을 비교했다.

동일한 값이면 LUCKY를, 아니면 READY를 출력하도록 한다.

 

 

 

 

 

 

'Algorithm > Python' 카테고리의 다른 글

[백준 1439번] 뒤집기  (0) 2022.03.09
[이코테] 모험가 길드  (0) 2022.03.09
[프로그래머스] 카펫  (0) 2022.03.05
[프로그래머스] 더 맵게  (0) 2022.03.04
[백준 7453번] 합이 0인 네 정수  (0) 2022.03.04

댓글