• 洛谷 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)

    题目大意:同细胞个数

    题解:可恶的字符串输入,毁我青春浪费我时间...

    scanf("%d ",**)不对,scanf("%d",&x);getline(cin,s);A了。

    debug时怀疑人生。

    代码:

    #include<iostream>
    #include<cstdio>
    #include<cstring>
    using namespace std;
    
    int n,ans,map[103][223];
    int mx[4]={0,1,-1,0},
        my[4]={-1,0,0,1};
    string s;
    
    void dfs(int x,int y){
        for(int i=0;i<4;i++){
            int xx=x+mx[i],yy=y+my[i];
            if(map[xx][yy]==0||xx<1||yy<1||yy>map[xx][0]||xx>n)continue;
            map[xx][yy]=0;
            dfs(xx,yy);
        }
    }
    
    int main(){
        scanf("%d",&n);getline(cin,s);
        for(int i=1;i<=n;i++){
            getline(cin,s);
            map[i][0]=s.length();
            for(int j=1;j<=map[i][0];j++){
                if(s[j-1]>='a'&&s[j-1]<='z')
                map[i][j]=1;
            }
        }
        for(int i=1;i<=n;i++){
            for(int j=1;j<=map[i][0];j++){
                if(map[i][j]){
                    map[i][j]=0;ans++;
                    dfs(i,j);
                }
            }
        }
        cout<<ans<<endl;
        return 0;
    }
  • 相关阅读:
    关于换行
    WebService
    C#操作XML的通用方法总结
    19个必须知道的Visual Studio快捷键
    Asp.net C# 把 Datatable转换成JSON 字符串
    C#中的多态性
    virtual和abstract
    DataTable的过滤需要的数据
    自定义控件之瀑布流与水波纹实现
    反转链表
  • 原文地址:https://www.cnblogs.com/zzyh/p/7602590.html
Copyright © 2020-2023  润新知