일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 백준
- dp
- 코딩테스트
- 순열
- OS
- 코딩 테스트
- kick start
- 그래프
- 운영체제
- PYTHON
- 브루트포스
- nlp
- 동적 프로그래밍
- BFS
- 구글 킥스타트
- 동적프로그래밍
- 리눅스
- 네트워크
- 프로그래머스
- google coding competition
- linux
- DFS
- AI
- CSS
- 알고리즘
- 딥러닝
- 파이썬
- 코딩
- 프로그래밍
- 킥스타트
- Today
- Total
오뚝이개발자
[백준14226] 이모티콘 본문
문제
https://www.acmicpc.net/problem/14226
생각의 흐름
결국 최종적으로는 화면에 n개의 이모티콘이 있어야 하는데 이 때, 클립보드에 있는 이모티콘의 갯수가 0~n-1개 일때중에서 어느 경우의 cost가 최소인지를 찾아야 한다는 점에 착안하여 BFS를 사용해야 한다는 것을 알 수 있다.(참고: 클립보드에 있는 이모티콘의 수는 항상 화면의 수보다 작거나 같다. 그런데 화면에 n개의 이모티콘이 있는 경우 마지막으로 클립보드에 복사하는 것은 불필요하기 때문에 상한선이 n이 아닌 n-1이 되는 것!!!)
코드에서 사용한 d[s][c]는 화면상에 s개의 이모티콘이 있고, 클립보드에 c개의 이모티콘이 있을 때 걸리는 시간값을 담고 있다. queue를 사용하여 매 s와 c의 값에 따라 갱신을 해주면 된다.
구현을 할 때에는 복사, 붙여넣기, 삭제의 세 가지 경우에 대한 것을 고려해주어야 하는데 이에 대한 각각의 상황은 코드에 주석으로 구분해 두었으니 참고하면 된다.
깨달은 점
의외로 이러한 cost의 최솟값을 구하는 문제에서 BFS를 사용해야 하는 경우가 많다. 그런데 그래프가 주어지고 전형적인 BFS를 사용하는 문제가 아닌 경우 BFS 알고리즘을 사용해야 한다는 것을 알아내기가 어렵다......
나름의 생각으로 결론을 내보자면
-
최종단계에 도달해서도 여러 경우의 수가 있고 그 중에서 최솟값을 구해야 하는 경우
-
최솟값을 결정짓는 요인이 한 가지가 아니어서(주로 2가지) 2차원 리스트를 직접 구현하고 갱신해가면서 결과값을 찾아야 하는 경우
위와 같은 경우에 주로 BFS를 사용하여 구현을 해야 하는 것 같다.
코드
import queue
n = int(input())
d = [[-1]*1001 for i in range(1001)]
d[1][0] = 0
q = queue.Queue()
q.put((1,0))
while q.qsize():
s, c = q.get()
# 복사
if d[s][s]==-1:
d[s][s]=d[s][c]+1
q.put((s,s))
# 붙여넣기
if s+c<=n and d[s+c][c]==-1:
d[s+c][c]=d[s][c]+1
q.put((s+c,c))
# 삭제
if s-1>=0 and d[s-1][c]==-1:
d[s-1][c]=d[s][c]+1
q.put((s-1,c))
# 화면에 이모티콘이 n개이면서 클립보드에 있는 이모티콘 수가 0~n-1개 일때 중에서 최솟값
ans=-1
for i in range(n):
if d[n][i]!=-1:
if ans==-1 or ans>d[n][i]:
ans=d[n][i]
print(ans)
'코딩 테스트 > 백준' 카테고리의 다른 글
[백준13023] ABCDE (0) | 2020.03.31 |
---|---|
[백준7576] 토마토 (0) | 2020.03.30 |
[백준2178] 미로 탐색 (0) | 2020.03.22 |
[백준2667] 단지번호붙이기 (0) | 2020.03.20 |
[백준1261] 알고스팟 (0) | 2020.03.18 |