[백준] 14719 - 빗물 🌧 (Python) / 골드 5 / 구현
- Programming/알고리즘
- 2022. 10. 6.
1. 문제🔥
링크: https://www.acmicpc.net/problem/14719
2차원 세계의 높이 H와 W가 주어지고, 그 다음 줄에는 각 열에 블록이 몇개씩 쌓여있는지가 주어집니다. 위 블록 이미지는 아래 예제 입력 2의 이미지 입니다. 고일 수 있는 빗물의 양을 출력하는 문제 입니다.
1) 예제 입출력❄️
2. 핵심 논리☢️
핵심은 각 블록에 대해서, 왼쪽과 오른쪽을 탐색해 두 방향 모두에서 더 높은 블록에 둘러 쌓여있으면 빗물이 고이는 것을 이용하는 것입니다. 자기를 둘러싼 왼쪽과 오른쪽 블록 중 더 낮을 블록까지 빗물이 고이는 것을 이용합니다.
3. 풀이 코드✅
H,W=[*map(int,input().split())]
blocks=[*map(int,input().split())]
result=0 # 빗물의 고인 양
for i in range(1, W-1): # 맨 왼쪽과 맨 오른쪽은 고일 수 없다.
left_max = max(blocks[:i]) # 왼쪽에서 제일 높은 블록
right_max = max(blocks[i+1:]) # 오른쪽에서 제일 높은 블록
lower_one = min(left_max, right_max) # 그중 가장 낮은 블록
if blocks[i] < lower_one: # 현재 블록이 lower_one 블록 보다는 낮아야 빗물이 고인다.
result += lower_one - blocks[i]
print(result)
H(높이)와 W(너비), blocks(각 열의 블록 개수)를 입력받고, 빗물이 고일양을 저장할 변수를 result=0으로 초기화해줍니다.
for 문을 도는데 맨 왼쪽 블록과 맨 오른쪽 블록은 빗물이 고일 수 없으므로 빼고 돕니다. 각 i 번째 블록에 대해서 왼쪽과 오른쪽을 모두 탐색해 각각 가장 높은 블록을 left_max와 right_max에 저장해 줍니다. 둘 중 더 작은 블록 까지만 빗물이 고이므로 min(left_max, right_max)를 해서 lower_one에 저장합니다. 현재 블록(blocks[i])보다 lower_one이 큰 경우, lower_one - blocks[i] 만큼의 빗물이 고이므로, 조건문으로 처리해 줍니다.
그렇게 각 블록에서 계산된 빗물이 고인양을 모두 result에 더해줘서 출력하면 됩니다.
저는 처음에 stack으로 풀어야 하나 이리저리 고민하다가, 풀이를 찾아보고 무릎을 탁 쳤습니다. 각 블록을 기준으로 생각해야 하는 구나를 느꼈습니다.
읽어주셔서 감사합니다.
다음에 더욱 유익한 글로 찾아오겠습니다.
* 관련 풀이 코드는 아래 깃허브 링크에 있습니다.
https://github.com/netsus/BaekJoon/blob/master/jupyter/14719_%EB%B9%97%EB%AC%BC.ipynb
Reference)
1. BAEKJOON Logo: https://www.acmicpc.net/
2. https://seongonion.tistory.com/115
'Programming > 알고리즘' 카테고리의 다른 글
[프로그래머스] 네트워크 🌐 (Python) / level3 / DFS (0) | 2022.10.14 |
---|---|
[백준] 1461 - 도서관 📚 (Python) / 골드 5 / 그리디 (0) | 2022.10.07 |
[프로그래머스] 구명보트🛶 (Python) / level2 / 구현 (0) | 2022.10.06 |
[프로그래머스] 큰 수 만들기 (Python) / level2 / 그리디 (1) | 2022.09.29 |
[백준] 12904 A와 B (BruteForce) - Python / 자세한 설명 / 골드5 (0) | 2022.07.28 |