洛谷 P1767 家族_NOI导刊2010普及(10)
生活随笔
收集整理的這篇文章主要介紹了
洛谷 P1767 家族_NOI导刊2010普及(10)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
P1767 家族_NOI導刊2010普及(10)
題目描述
在一個與世隔絕的島嶼上,有一個有趣的現象:同一個家族的人家總是相鄰的(這里的相鄰是指東南西北四個方向),不同的家族之間總會有河流或是山丘隔絕,但同一個家族的人不一定有相同姓氏。現在給你島上的地圖,求出島上有多少個不同的家族。島上的地圖有n行,每行有若干列,每個格子中要么是“ ”,表示大海,要么是“*”,表示河流或山丘,要么是小寫字母,表示一戶人家的姓氏。
輸入輸出格式
輸入格式:?
第一行是個數字N,表示下面信息的行數。接下來是N行字符,每行由小寫字母和*號組成,有些行的最前面也可能包含若干連續的空格,表示這些區域是大海,每一行最多不超過200個字符。
?
輸出格式:?
一個數字,表示家族數。
?
輸入輸出樣例
輸入樣例#1:4 *zlw**pxh l*zlwk*hx* w*tyy**yyyzzl 輸出樣例#1:
3
說明
10%的數據,n≤1。 30%的數據,n≤10。 100%的數據,n≤100每一行最多不超過200個字符。
_NOI導刊2010普及(10)
思路:諤諤,大水題。
#include<iostream> #include<cstdio> #include<algorithm> #include<cstring> using namespace std; int dx[4]={1,0,0,-1}; int dy[4]={0,1,-1,0}; char c[210],a[210]; int n,m,num,map[110][210],vis[110][210]; void dfs(int X,int Y){for(int i=0;i<4;i++){int cx=dx[i]+X;int cy=dy[i]+Y;if(cx>=1&&cx<=n&&cy>=1&&cy<=m&&!vis[cx][cy]&&!map[cx][cy]){vis[cx][cy]=1;dfs(cx,cy); }} } int main(){//freopen("family.in","r",stdin);//freopen("family.out","w",stdout);scanf("%d",&n);memset(map,-1,sizeof(map));gets(c);for(int i=1;i<=n;i++){gets(c);int len=strlen(c);for(int j=0;j<len;j++)if(c[j]>='a'&&c[j]<='z') map[i][j+1]=0;m=max(len,m);}for(int i=1;i<=n;i++)for(int j=1;j<=m;j++)if(!map[i][j]&&!vis[i][j]){num++;dfs(i,j);}cout<<num; }?
轉載于:https://www.cnblogs.com/cangT-Tlan/p/7506065.html
總結
以上是生活随笔為你收集整理的洛谷 P1767 家族_NOI导刊2010普及(10)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 图解Javascript——作用域、作用
- 下一篇: 242.判断一个字符串是否为另一个的乱序