日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

洛谷 P1767 家族_NOI导刊2010普及(10)

發布時間:2024/7/19 55 豆豆
生活随笔 收集整理的這篇文章主要介紹了 洛谷 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)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。