全球变暖(蓝桥杯18I)

cpp 复制代码
#include<iostream>
#define D 7
using namespace std;
char map[D][D];
int x[] = { -1,1,0,0 };
int y[] = { 0,0,1,-1 };
void dfs(int a,int b) {
	map[a][b] = '*';
	for (int i = 0; i < 4;i++) {
		int nx = a + x[i];
		int ny = b + y[i];
		if (map[nx][ny] == '#') {
			dfs(nx,ny);
		}
	}
}
int cheak_Num() {
	int cnt = 0;
	for (int i = 0; i < D;i++) {
		for (int j = 0; j < D;j++) {
			if (map[i][j] == '#') {
				dfs(i,j);
				cnt++;
			}
		}
	}
	return cnt;
}
void drown() {
	for (int i = 0; i < D;i++) {
		for (int j = 0; j < D; j++) {
			if (map[i][j] == '#') {
				int cnt = 0;
				for (int z = 0; z < 4;z++) {
					int nx = i + x[z];
					int ny = j + y[z];
					if (map[nx][ny] == '#' || map[nx][ny] == '*') {
						cnt++;
					}
				}
				if (cnt < 4) {
					map[i][j] = '*';
				}
			}
		}
	}
}
int main() {
	for (int i = 0; i < D;i++) {
		for (int j = 0; j < D;j++) {
			cin >> map[i][j];
			getchar();
		}
	}
	int bf = cheak_Num();
	drown();
	int last = cheak_Num();
    cout<<(bf - last;
	return 0;
cpp 复制代码
#include<iostream>
using namespace std;
bool flag;
char a[1010][1010];
int cnt = 0;
int n;
int dx[4] = { 1,-1,0,0 };
int dy[4] = { 0,0,1,-1 };
int ans = 0;
int rans = 0;
void dfs(int x,int y) {
	if (a[x][y] != '#') {
		return;
	}
	if (x>=n||x<0||y>=n||y<0) {
		return;
	}
	if (!flag) {
		cnt = 0;
		for (int i = 0; i < 4;i++) {
			int nx = x + dx[i];
			int ny = y + dy[i];
			if (nx < n&& nx>=0&&ny<n&&ny>=0&& a[nx][ny] != '.') {
				cnt++;
			}
		}
		if (cnt == 4) {
			ans++;
			flag = true;
		}
	}
	a[x][y] = '*';
	for (int i = 0; i < 4; i++) {
		int nx = x + dx[i];
		int ny = y + dy[i];
		dfs(nx, ny);
	}
}
int main() {
	cin >> n;
	for (int i = 0; i < n;i++) {
		for (int j = 0; j < n;j++) {
			cin >> a[i][j];
		}
	}
	for (int i = 0; i < n; i++) {
		for (int j = 0; j < n; j++) {
			if (a[i][j] == '#') {
				rans++;
				flag = false;
				dfs(i,j);
			}
		}
	}
	return 0;
}
相关推荐
编程大师哥20 分钟前
C++类和对象
开发语言·c++·算法
加农炮手Jinx1 小时前
LeetCode 146. LRU Cache 题解
算法·leetcode·力扣
Rabitebla1 小时前
C++ 和 C 语言实现 Stack 对比
c语言·数据结构·c++·算法·排序算法
加农炮手Jinx1 小时前
LeetCode 128. Longest Consecutive Sequence 题解
算法·leetcode·力扣
旖-旎1 小时前
递归(汉诺塔问题)(1)
c++·学习·算法·leetcode·深度优先·递归
深邃-1 小时前
【数据结构与算法】-顺序表链表经典算法
java·c语言·数据结构·c++·算法·链表·html5
努力学习的小廉1 小时前
我爱学算法之—— 前缀和(上)
c++·算法
AC17801 小时前
深入浅出 PID 算法:原理、实现与应用实战
人工智能·算法·机器学习
就爱学编程1 小时前
惊叹数据结构之美,品味排序算法之妙:对计排、桶排的详细介绍
数据结构·算法·排序算法
啊我不会诶1 小时前
2025CCPC福建邀请赛补题
算法·深度优先