https://www.acmicpc.net/problem/18406
럭키 스트레이트
시간 제한메모리 제한제출정답맞은 사람정답 비율
1 초 | 256 MB | 2645 | 1928 | 1563 | 72.630% |
문제
어떤 게임의 아웃복서 캐릭터에게는 럭키 스트레이트라는 기술이 존재한다. 이 기술은 매우 강력한 대신에 항상 사용할 수는 없으며, 현재 게임 내에서 점수가 특정 조건을 만족할 때만 사용할 수 있다.
특정 조건이란 현재 캐릭터의 점수를 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
정답코드
n = input()
k = len(n)//2
left = list(map(int, n[:k]))
right = list(map(int, n[k:]))
if sum(left) == sum(right):
print("LUCKY")
else:
print("READY")
해설
n = input()
입력값을 문자열 리스트로 받는다.
n = ["1", "2", "3", "4", "0", "2"]
k = len(n)//2
n의 길이를 절반으로 나눠서 가운데 인덱스를 구한다.
k = 6//2 = 3
# 리스트에는 안담아도 됨
left = list(map(int, n[:k]))
right = list(map(int, n[k:]))
- n[:k] 리스트 n의 0번째(생략하면 0부터) 값부터 k-1번째 값까지
- n[:k] = ["1", "2", "3"]
- map(int, n[:k]) n[:k]의 값들을 int형으로 바꿔서 map에 담은 값
- left = [1, 2, 3]
- n[k:] 리스트 n의 k번째 값부터 마지막까지
- right = [4, 0, 2]
if sum(left) == sum(right):
print("LUCKY")
else:
print("READY")
sum(left) 리스트 left에 있는 값의 합을 구해준다.
sum(left) = 1 + 2 + 3 = 6
sum(right) = 4 + 0 + 2 =6
같으면 "LUCKY" 출력
'코딩테스트 > 백준' 카테고리의 다른 글
[백준] 9370번 : 미확인 도착지 / 다익스트라(Dijkstra) / 파이썬 Python (0) | 2021.07.29 |
---|---|
[백준] 1504번 : 특정한 최단경로 / 다익스트라(Dijkstra) / 파이썬 Python (0) | 2021.07.29 |
[백준] 1753번 : 최단경로 / 다익스트라(Dijkstra) / 파이썬 Python (0) | 2021.07.29 |
[백준] 11653번: 소인수 분해 / 파이썬 (1) | 2021.07.29 |
[백준] 7576번 : 토마토 / BFS / 파이썬 Python (0) | 2021.06.22 |