全球变暖(蓝桥杯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;
}
相关推荐
mit6.8246 小时前
bfs|栈
算法
CoderYanger7 小时前
优选算法-栈:67.基本计算器Ⅱ
java·开发语言·算法·leetcode·职场和发展·1024程序员节
jllllyuz7 小时前
Matlab实现基于Matrix Pencil算法实现声源信号角度和时间估计
开发语言·算法·matlab
稚辉君.MCA_P8_Java7 小时前
DeepSeek 插入排序
linux·后端·算法·架构·排序算法
多多*7 小时前
Java复习 操作系统原理 计算机网络相关 2025年11月23日
java·开发语言·网络·算法·spring·microsoft·maven
덕화8 小时前
【面试宝典】线上问题逆向分析1
面试·职场和发展
美团程序员8 小时前
一篇文章教你搞定:”xx 功能如何测试?“常见面试题型!
测试工具·面试·职场和发展·测试用例
.YM.Z8 小时前
【数据结构】:排序(一)
数据结构·算法·排序算法
Chat_zhanggong3458 小时前
K4A8G165WC-BITD产品推荐
人工智能·嵌入式硬件·算法
百***48079 小时前
【Golang】slice切片
开发语言·算法·golang