문제 설명
일렬로 나열된 n개의 풍선이 있습니다. 모든 풍선에는 서로 다른 숫자가 써져 있습니다. 당신은 다음 과정을 반복하면서 풍선들을 단 1개만 남을 때까지 계속 터트리려고 합니다.
- 임의의 인접한 두 풍선을 고른 뒤, 두 풍선 중 하나를 터트립니다.
- 터진 풍선으로 인해 풍선들 사이에 빈 공간이 생겼다면, 빈 공간이 없도록 풍선들을 중앙으로 밀착시킵니다.
여기서 조건이 있습니다. 인접한 두 풍선 중에서 번호가 더 작은 풍선을 터트리는 행위는 최대 1번만 할 수 있습니다. 즉, 어떤 시점에서 인접한 두 풍선 중 번호가 더 작은 풍선을 터트렸다면, 그 이후에는 인접한 두 풍선을 고른 뒤 번호가 더 큰 풍선만을 터트릴 수 있습니다.
당신은 어떤 풍선이 최후까지 남을 수 있는지 알아보고 싶습니다. 위에 서술된 조건대로 풍선을 터트리다 보면, 어떤 풍선은 최후까지 남을 수도 있지만, 어떤 풍선은 무슨 수를 쓰더라도 마지막까지 남기는 것이 불가능할 수도 있습니다.
일렬로 나열된 풍선들의 번호가 담긴 배열 a가 주어집니다. 위에 서술된 규칙대로 풍선들을 1개만 남을 때까지 터트렸을 때 최후까지 남기는 것이 가능한 풍선들의 개수를 return 하도록 solution 함수를 완성해주세요.
def solution(a):
answer = 0 # 조건을 만족하는 원소의 개수를 저장할 변수
left_max, right_max = float('inf'), float('inf') # 초기 최대값 설정 (무한대)
n = len(a) # 배열 a의 길이
left = left_max # 왼쪽에서부터 확인할 최소값
right = right_max # 오른쪽에서부터 확인할 최소값
left_list = [] # 왼쪽부터 각 원소까지의 최소값을 저장할 리스트
right_list = [] # 오른쪽부터 각 원소까지의 최소값을 저장할 리스트
# 왼쪽부터 각 원소까지의 최소값을 계산하여 left_list에 저장
for i in range(n):
left = min(left, a[i]) # 현재 원소와 이전까지의 최소값을 비교하여 저장
left_list.append(left) # 계산된 최소값을 left_list에 추가
# 오른쪽부터 각 원소까지의 최소값을 계산하여 right_list에 저장
for i in range(n-1, -1, -1):
right = min(right, a[i]) # 현재 원소와 이전까지의 최소값을 비교하여 저장
right_list.append(right) # 계산된 최소값을 right_list에 추가
right_list.reverse() # right_list는 오른쪽에서 왼쪽으로 저장했기 때문에 순서를 뒤집어줌
# a 배열의 각 원소에 대해, 해당 원소가 왼쪽 또는 오른쪽에서 계산된 최소값보다 작거나 같으면 조건을 만족
for i in range(len(a)):
if a[i] <= left_list[i] or a[i] <= right_list[i]:
answer += 1 # 조건을 만족하면 answer를 증가시킴
return answer # 조건을 만족하는 원소의 개수를 반환
'코딩 테스트' 카테고리의 다른 글
코딩 테스트(Python) 2020 KAKAO BLIND RECRUITMENT 자물쇠와 열쇠 (1) | 2024.12.20 |
---|---|
코딩 테스트(Python) 순위 (0) | 2024.12.20 |
코딩 테스트(Python) 거스름돈 (2) | 2024.12.20 |
코딩 테스트(Python) 다단계 칫솔 판매 (2) | 2024.12.20 |
코딩 테스트(Python) 2018 KAKAO BLIND RECRUITMENT[1차] 셔틀버스 (0) | 2024.12.19 |