P1767 家族_NOI导刊2010普及(10)
题目描述
在一个与世隔绝的岛屿上,有一个有趣的现象:同一个家族的人家总是相邻的(这里的相邻是指东南西北四个方向),不同的家族之间总会有河流或是山丘隔绝,但同一个家族的人不一定有相同姓氏。现在给你岛上的地图,求出岛上有多少个不同的家族。岛上的地图有n行,每行有若干列,每个格子中要么是“ ”,表示大海,要么是“*”,表示河流或山丘,要么是小写字母,表示一户人家的姓氏。
输入输出格式
输入格式:
第一行是个数字N,表示下面信息的行数。接下来是N行字符,每行由小写字母和*号组成,有些行的最前面也可能包含若干连续的空格,表示这些区域是大海,每一行最多不超过200个字符。
输出格式:
一个数字,表示家族数。
输入输出样例
输入样例#1:
4 *zlw**pxh l*zlwk*hx* w*tyy**yyy zzl
输出样例#1:
3
说明
10%的数据,n≤1。 30%的数据,n≤10。 100%的数据,n≤100每一行最多不超过200个字符。
_NOI导刊2010普及(10)
mdzz,什么鬼畜的字符串读入!
气死我了!
#include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #define N 500 using namespace std; string ch; int n,l[N],a[N][N],ans; int xx[4]={0,0,-1,1},yy[4]={1,-1,0,0}; int dfs(int x,int y) { a[x][y]=false; for(int i=0;i<4;i++) { int fx=x+xx[i],fy=y+yy[i]; if(fx<1||fy<1||fx>n||fy>l[fx]||!a[fx][fy]) continue; dfs(fx,fy); } } int main() { scanf("%d",&n);getline(cin,ch); for(int i=1;i<=n;i++) { getline(cin,ch); l[i]=ch.length(); for(int j=1;j<=l[i];j++) if(ch[j-1]>=‘a‘&&ch[j-1]<=‘z‘) a[i][j]=1; } for(int i=1;i<=n;i++) for(int j=1;j<=l[i];j++) if(a[i][j]) ans++,dfs(i,j); printf("%d",ans); return 0; }
时间: 2024-11-04 11:36:52