题目描述
培养皿可以被看成一个n*n的方格,最初病菌滴在了这n*n的格子中的某些格子,病菌的传染方式是这样的,如果一个方格与两个或多个被感染的方格相邻(两个方格相邻当且仅当它们只有一条公共边),
那么它就会被感染。现在铁子和顺溜想知道,最终所有的方格会不会都被感染。
输入描述:
第一行两个整数n,m。n表示方格的规格,m表示最初病菌所在的格子数。(1 ≤ n ≤ 1000, 0 < m < n)。
输出描述:
如果最终所有的方格都会被感染,输出 YES。
否则输出 NO。
解题思路与易错分析:
看到这个题应该会联系到棋盘类的题目,也就是对二维数组的理解与运用,可能会有人和我犯一样的错误,就是对数组越界问题的考虑(当然只对于刚学习编程的人来说),因为可以对数组进行越界访问,但是越界的数组的值是不确定的,可能为任意的值,说一下解决的方法其实思路也简单,
第一种就是定义更大的数组然后用中间的部分,这样也就避免了数组的越界。
第二中就是在进行判断是加条件判断移动的是否已经越界(和算法竞赛入门经典中蛇形填数用法一样)简单的说就是,先判断其中条件为当前的元素为已经感染的而且移动后的行数与列数既不能大于最大的也不能小于最小的
法二在这里用有点麻烦,所以我选用第一种的方法:
下面附上我的代码:
#include <iostream>
using namespace std;
int ceil[1004][1004] = {0};
int n,m,x,y;;
int main()
{
cin >> n >> m;
for(int i = 1; i <= m; i++)
{
cin >> x >> y;
ceil[x][y] = 1;
}
for(int i = 1; i <= n; i++)
{
for(int j = 1; j <=n; j++)
{
if(!ceil[i][j])
{
int cnt = 0;
if(ceil[i+1][j]) cnt++;
if(ceil[i-1][j]) cnt++;
if(ceil[i][j+1]) cnt++;
if(ceil[i][j-1]) cnt++;
if(cnt >= 2) ceil[i][j] = 1;
else
{
cout << "NO\n";
return 0;
}
}
}
}
cout << "YES\n";
return 0;
}