hiho week 232 register

Ended

Participants:110

Verdict:Accepted
Score:100 / 100
Submitted:2018-12-11 17:25:33

Lang:G++

Edit
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
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int N, M;
int starti, startj, endi, endj;
vector<vector<char>> numLst(501, vector<char>(501));
vector<vector<int>> ans(501, vector<int>(501, 0));
void dfs(int i, int j, int cnt) {
    starti = min(i, starti);
    startj = min(j, startj);
    endi = max(i, endi);
    endj = max(j, endj);
    ans[i][j] = cnt;
    if (j > 0 && numLst[i][j - 1] == '1' && !ans[i][j - 1])
        dfs(i, j - 1, cnt);
    if (j < M - 1 && numLst[i][j + 1] == '1' && !ans[i][j + 1])
        dfs(i, j + 1, cnt);
    if (i > 0 && numLst[i - 1][j] == '1' && !ans[i - 1][j])
        dfs(i - 1, j, cnt);
    if (i < N - 1 && numLst[i + 1][j] == '1' && !ans[i + 1][j])
        dfs(i + 1, j, cnt);
}
int main()
{
    cin >> N >> M;
    for (int i = 0; i < N; ++i)
        for (int j = 0; j < M; ++j)
            cin >> numLst[i][j];
    int cnt = 1;
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX