描述
一矩形阵列由数字0到9组成,数字1到9代表细胞,细胞的定义为沿细胞数字上下左右若还是细胞数字则为同一细胞,求给定矩形阵列的细胞个数。(1<=m,n<=100)
这题是一道深搜题,只要不是0就计数,然后深搜;
下面出示代码:
#include <bits/stdc++.h>
using namespace std;
int n,m,cnt;
char a[100][100];
void shensourumenyouduoshaoxibao(int x,int y){
if(x<1||y<1||x>n||y>m||a[x][y]=='0')return;
a[x][y]='0';
shensourumenyouduoshaoxibao(x+1,y);
shensourumenyouduoshaoxibao(x-1,y);
shensourumenyouduoshaoxibao(x,y+1);
shensourumenyouduoshaoxibao(x,y-1);
}
int main() {
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>a[i][j];
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
if(a[i][j]!='0'){
cnt++;
shensourumenyouduoshaoxibao(i,j);
}
}
}
cout<<cnt;
return 0;
}

被折叠的 条评论
为什么被折叠?



