반응형
알고리즘 종류
- 구현
사고 과정
- 빗물이 고인다는 것은 양쪽에 벽이 있다는 것을 의미한다. 따라서, 벽이 나타나면, 같은 행에서 다른 벽이 있는지 확인하고 차이 만큼 빗물이 고인다.
구현(C++)
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
32
33
34
35
36
37
38
39
40
41
42
|
#include <iostream>
using namespace std;
int H, W;
int answer = 0;
int mat[501][501];
void solution(){
for(int i=0; i<H; i++){
for(int j=0; j<W; j++){
if(!mat[i][j]) continue;
int idx = j;
while(!mat[i][++idx] && idx<W);
if(idx>=W) break;
answer += idx - j - 1;
j = idx - 1;
}
}
cout << answer;
}
int main(void){
cin >> H >> W;
int blocks;
for(int i=0; i<W; i++){
cin >> blocks;
for(int j=H-1; j>=H-blocks; j--){
mat[j][i] = 1;
}
}
solution();
}
|
cs |
시행착오
반응형
'코딩 공부 > 백준' 카테고리의 다른 글
[백준][C++] 2352 반도체 설계 (0) | 2021.02.27 |
---|---|
[백준][C++] 2467 용액 (0) | 2021.02.27 |
[백준][C++] 1956 운동 (0) | 2021.02.25 |
[백준][C++] 4485 녹색 옷 입은 애가 젤다지? (0) | 2021.02.25 |
[백준][C++] 2263 트리의 순회 (0) | 2021.02.24 |