- 문제
일렬로 나열된 n개의 풍선이 있습니다. 모든 풍선에는 서로 다른 숫자가 써져 있습니다. 당신은 다음 과정을 반복하면서 풍선들을 단 1개만 남을 때까지 계속 터트리려고 합니다.
- 임의의 인접한 두 풍선을 고른 뒤, 두 풍선 중 하나를 터트립니다.
- 터진 풍선으로 인해 풍선들 사이에 빈 공간이 생겼다면, 빈 공간이 없도록 풍선들을 중앙으로 밀착시킵니다.
여기서 조건이 있습니다. 인접한 두 풍선 중에서 번호가 더 작은 풍선을 터트리는 행위는 최대 1번만 할 수 있습니다. 즉, 어떤 시점에서 인접한 두 풍선 중 번호가 더 작은 풍선을 터트렸다면, 그 이후에는 인접한 두 풍선을 고른 뒤 번호가 더 큰 풍선만을 터트릴 수 있습니다.
당신은 어떤 풍선이 최후까지 남을 수 있는지 알아보고 싶습니다. 위에 서술된 조건대로 풍선을 터트리다 보면, 어떤 풍선은 최후까지 남을 수도 있지만, 어떤 풍선은 무슨 수를 쓰더라도 마지막까지 남기는 것이 불가능할 수도 있습니다.
일렬로 나열된 풍선들의 번호가 담긴 배열 a가 주어집니다. 위에 서술된 규칙대로 풍선들을 1개만 남을 때까지 터트렸을 때 최후까지 남기는 것이 가능한 풍선들의 개수를 return 하도록 solution 함수를 완성해주세요.
- 제한사항
- a의 길이는 1 이상 1,000,000 이하입니다.
- a[i]는 i+1 번째 풍선에 써진 숫자를 의미합니다.
- a의 모든 수는 -1,000,000,000 이상 1,000,000,000 이하인 정수입니다.
- a의 모든 수는 서로 다릅니다.
- a의 길이는 1 이상 1,000,000 이하입니다.
- 입/출력
a | result |
[9,-1,-5] | 3 |
[-16,27,65,-2,58,-92,-71,-68,-61,-33] | 6 |
- 코드
def solution(a):
boo = [False]*len(a)
front, end = 1e+9+1, 1e+9+1
for i in range(len(a)):
if a[i] < front:
front = a[i]
boo[i] = True
if a[-1-i] < end:
end = a[-1-i]
boo[-1-i] = True
return sum(boo)
맨앞에서부터 맨뒤로가는 포인터와 맨뒤에서부터 맨앞으로가는 포인터가 있다고 생각하면된다.
무조건 큰 수를 제거하고 딱 1번만 작은수를 제거한는것이 가능하다고 적혀있다.
그래서 해당 값보다 작은경우가 아니면(즉, 크다면) False를 넣는것이다. 그러나 1번만 작은수를 제거하는것이 가능하기때문에 지금 방향은 양쪽에서 오고있기 때문에 double check를한다. 그래서 앞에서 시작할때 큰수여서 False로 들어가더라도 뒤에서 올때 작다면 풍선을 남길수 있기 때문에 True로 바꾸어준다.
- 출처
programmers.co.kr/learn/courses/30/lessons/68646?language=python3
'알고리즘' 카테고리의 다른 글
프로그래머스 괄호 회전하기 (python, 파이썬) (0) | 2021.04.20 |
---|---|
프로그래머스 징검다리 건너기 (python, 파이썬) (0) | 2021.04.20 |
프로그래머스 모두 0으로 만들기 (python, 파이썬) (0) | 2021.04.19 |
프로그래머스 스타수열 (python, 파이썬) (0) | 2021.04.18 |
프로그래머스 2020 KAKAO 인턴 경주로 건설 (python, 파이썬) (0) | 2021.04.16 |
댓글