-
문제
이 문제의 대체재로 "LeetCode의 42. Trapping Rain Water" 를 푸셔도 무관합니다 :)
https://www.acmicpc.net/problem/14719
14719번: 빗물
첫 번째 줄에는 2차원 세계의 세로 길이 H과 2차원 세계의 가로 길이 W가 주어진다. (1 ≤ H, W ≤ 500) 두 번째 줄에는 블록이 쌓인 높이를 의미하는 0이상 H이하의 정수가 2차원 세계의 맨 왼쪽 위치
www.acmicpc.net
How to Solve ?
[1] Two Pointer
전형적인 투포인터 문제로써, [ left / right ] 포인터를 이동시키면 빗물의 양을 계산하는 문제이다.
왜 투포인터를 쓰는가? 생각해보면 [3,1,2] 이라는 인풋이 주어 지는 경우
1 - 1) 3부터 시작
3부터 시작하는 경우 3 -1 => 2만큼의 물이 차있어야 할 것을 예상하지만 다음 기둥의 높이가 1이기에 2만큼의 물을 담을 수 없다.
이런 원리로 앞의 길이가 길어도 뒤의 길이가 짧으면 물을 담을 수 없기에 기둥의 크기를 비교하여 작은 값부터 연산을 하는 것이다.
function solution(height) { let answer = 0; let left = 0; let right = height.length - 1; let maxLeft = 0; let maxRight = 0; while (left < right) { if (height[left] < height[right]) { if (height[left] >= maxLeft) { maxLeft = height[left]; } else { answer += maxLeft - height[left]; } left++; } else { if (height[right] >= maxRight) { maxRight = height[right]; } else { answer += maxRight - height[right]; } right--; } } return answer; } const fs = require("fs"); const input = fs.readFileSync("/dev/stdin").toString().split("\n"); const [H, W] = input[0].split(" ").map((x) => +x); const height = input[1].split(" ").map((x) => +x); // 테스트용 인풋 // let [N, K] = [4, 8]; // let height = [3, 1, 2, 3, 4, 1, 1, 2]; console.log(solution(height));
Result
'PS > 백준' 카테고리의 다른 글
[ 백준_2293 ] 동전 1 ( DP, by using JavaScript ) (0) 2021.06.03 [백준_2437] 저울 ( by using Javascript ) (0) 2021.06.03 [백준_14888] 연산자 끼워넣기 ( by using JavaScript ) (0) 2021.06.01 [백준_1697] 숨바꼭질 ( by using JavaScript ) (0) 2021.05.28 [ 알고리즘 로드맵 ] (0) 2021.05.06 댓글