全球变暖(蓝桥杯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;
}
相关推荐
xie_pin_an3 分钟前
C 语言排序算法全解析:从原理到实战,附性能对比
c语言·算法·排序算法
CoovallyAIHub5 分钟前
SAM 真的开始「分割一切」,从图像到声音,Meta 开源 SAM Audio
深度学习·算法·计算机视觉
三斗米9 分钟前
从思维链到思维树:一步步解锁大语言模型的推理能力
算法
前端小L22 分钟前
贪心算法专题(二):波动中的智慧——只取极值「摆动序列」
数据结构·算法·贪心算法
aini_lovee22 分钟前
基于Jousselme距离改进D-S证据理论matlab实现
开发语言·算法·matlab
白兰地空瓶32 分钟前
你以为树只是画图?不——它是算法面试的“隐形主角”
前端·javascript·算法
好易学·数据结构42 分钟前
可视化图解算法74:最小花费爬楼梯
数据结构·算法·leetcode·动态规划·力扣
Maỿbe1 小时前
力扣hot图论部分
算法·leetcode·图论
LYFlied1 小时前
【每日算法】LeetCode 78. 子集
数据结构·算法·leetcode·面试·职场和发展
月明长歌1 小时前
【码道初阶】【Leetcode606】二叉树转字符串:前序遍历 + 括号精简规则,一次递归搞定
java·数据结构·算法·leetcode·二叉树