赞
踩
// // Created by xiaoyu on 2019/9/27. // #include <iostream> using namespace std; const int n = 3, m = 5; int dir[4][2] = {{-1, 0},{1, 0}, {0, 1}, {0, -1}}; int vis[n][m]; int maps[n][m] = { 0,1,0,0,1, 0,0,1,1,1, 1,0,1,1,0, }; int valid(int x, int y) { return x >= 0 && x < n && y >= 0 && y < m && !vis[x][y] && maps[x][y] == 0; } void dfs(int x, int y) { for (int i = 0; i < 4; i++) { int nx = x + dir[i][0], ny = y + dir[i][1]; if (valid(nx, ny)) { vis[nx][ny] = 1; dfs(nx, ny); } } } int main() { int cnt = 0; for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { if (!vis[i][j] && maps[i][j] == 0) { dfs(i, j); cnt++; } } } cout << cnt << endl; }
// // Created by xiaoyu on 2019/9/27. // #include <iostream> #include <cmath> using namespace std; const int maxn = 100, n = 3, m = 5; int pre[n * m]; int dir[4][2] = {{-1, 0}, {1, 0}, {0, 1}, {0, -1}}; int maps[3][5] = { 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 0, }; struct Node { int x, y; } Point[n * m]; int find(int x) { return x == pre[x] ? x : pre[x] = find(pre[x]); //路径压缩 } void Union(int x, int y) { int fx = find(x), fy = find(y); if (fx != fy) { pre[fx] = fy; } } int main() { int len = 0; //0的个数 for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { if (maps[i][j] == 0) { Point[len++] = Node{i, j}; } } } for (int i = 0; i < len; i++) { pre[i] = i; //初始化,每个点的祖先都是自己 } for (int i = 0; i < len; i++) { int x = Point[i].x, y = Point[i].y; for (int j = i + 1; j < len; j++) { int nx = Point[j].x, ny = Point[j].y; if (abs(x - nx) + abs(y - ny) == 1) { //这样相邻的点可以合并 Union(i, j); } } } int cnt = 0; for (int i = 0; i < len; i++) { if (i == find(i)) cnt++; //这样的点就是祖先节点 } for (int i = 0; i < len; i++) cout << pre[i] << " "; cout << endl; cout << cnt << endl; }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。