Dfs【p1454】 圣诞夜的极光

题目描述-->p1454 圣诞夜的极光

题意概括:

寻找联通块数量,这里的连通块定义与其他的不同.

这里定义为曼哈顿距离不超过2的都属于一个联通块.

什么?不知道曼哈顿距离是啥?

曼哈顿距离简易概括->|x1-x2|+|y1-y2|,两点之间横纵坐标的差的绝对值之和.

详细解释->曼哈顿距离

分析

看到大家都在说12个方向,具体是哪12个方向呢?

假设黄色点为我们当前所在节点.那我们图中标出的红色点,都是满足与黄色点曼哈顿距离为2的点.

5b9502e9a2284.png

但这才有8个方向啊!

回望题意,曼哈顿距离不超过2的都属于一个联通块

曼哈顿距离不超过2,那我们的图应该是这样的↓.

(蓝色点即为与黄色点曼哈顿距离为1的.

5b9503062d48b.png

所以说,现在12个方向就很明确了!

根据标明的坐标,我们很容易打出12个方向对应的位置变化. 像这样↓

const int ax[]={-1,-2,1,2,0,0,0,0,1,1,-1,-1};
const int ay[]={0,0,0,0,1,2,-1,-2,1,-1,1,-1};
//const类型可自动识别数组大小.
//不过貌似不加const也可以识别

然后我们我又遇到了难题,

如何输入?

字符类型,我们一般选择用

scanf("%c"),getchar(),cin来进行输入.

但是这题,用scanf,会出现蜜汁错误.(用scanf只get到了30pts...

而用getchar则会读取行末换行符,需要加判断.

所以我们直接选用cin来读入字符.(感觉cin输入字符还是很少出锅的.

因此,我们搜到一个为'#'的位置,就去标记与它在一个联通块中的位置,则联通块个数++即可.

PS:

or ==> ||
and==> &&

---------------------代码--------------------

#include<bits/stdc++.h>
#define IL inline
#define RI register int
IL void in(int &x)
{
    int f=1;x=0;char s=getchar();
    while(s>'9' or s<'0'){if(s=='-')f=-1;s=getchar();}
    while(s>='0' and s<='9'){x=x*10+s-'0';s=getchar();}
    x*=f;
}
int n,m,ans;
char res[108][108];
const int ax[]={-1,-2,1,2,0,0,0,0,1,1,-1,-1};
const int ay[]={0,0,0,0,1,2,-1,-2,1,-1,1,-1};
bool vis[108][108];
IL void dfs(int x,int y)
{
    if(vis[x][y])return;
    vis[x][y]=true;
    for(RI i=0;i<12;i++)
    {
        int nx=x+ax[i],ny=y+ay[i];
        if(nx<1 or ny<1 or nx>n or ny>m )continue;
        if(res[nx][ny]=='#'and !vis[nx][ny])dfs(nx,ny);
    }
}
int main()
{
    in(n),in(m);
    for(RI i=1;i<=n;i++)
        for(RI j=1;j<=m;j++)
            std::cin>>res[i][j];
    for(RI i=1;i<=n;i++)
        for(RI j=1;j<=m;j++)
        {
            if(res[i][j]=='#' and !vis[i][j])
            {
                dfs(i,j);
                ans++;
            }
        }
    printf("%d",ans);
}

转载于:https://www.cnblogs.com/-guz/p/9614492.html

### 回答1: hdfs dfs -mkdir -p 是一个Hadoop命令,用于在HDFS中创建目录。其中,-p选项表示如果父目录不存在,则创建父目录。例如,如果要在HDFS中创建一个名为/data/input的目录,可以使用以下命令: hdfs dfs -mkdir -p /data/input ### 回答2: "hdfs dfs -mkdir -p"是一个Hadoop分布式文件系统(HDFS)命令,用于创建一或多个目录。其中,"-p"选项可在需要时递归创建所需目录。 HDFS是一个分布式文件系统,其主要功能是将大型文件拆分成较小的块,然后存储在Hadoop群集中的不同节点上。该文件系统具有高容错性,可用性和可扩展性。 “-mkdir”命令是用于创建目录的基本命令,而“-p”选项是可选的。在以下情况中,“-p”选项非常有用: 1. 当需要创建多层次嵌套的目录时,使用该选项可以确保所有嵌套目录都创建成功; 2. 如果要创建的目录的父级目录不存在,则使用该选项可以自动创建父级目录。 例如,您希望在HDFS文件系统中创建一个名为“/user/hadoop/data”的目录。如果“/user/hadoop”目录不存在,则使用以下命令: hdfs dfs -mkdir -p /user/hadoop/data 该命令将自动创建父级目录“/user/hadoop”,然后创建“/user/hadoop/data”目录。 总之,“hdfs dfs -mkdir -p”命令是在Hadoop集群中创建目录的常用命令,可以快速创建所需目录并递归地创建其父级目录。 ### 回答3: hdfs dfs -mkdir -p是一个Hadoop分布式文件系统(HDFS)的命令。其中-hdfs代表Hadoop分布式文件系统,dfs表示分布式文件系统,mkdir表示创建目录的命令,而-p则表示如果目录无法直接创建,就创建父目录,即自动创建所有中间目录。 在HDFS中,我们使用命令来创建、删除和管理文件和目录。其中,mkdir命令可以帮助我们创建新的目录。但如果要创建的目录所在的中间目录并不存在,就会失败。如果加入了-p参数,就会在创建目标目录的同时,自动创建其所在的中间目录。这个参数的作用类似于Linux中的mkdir -p命令。 例如,如果想要在HDFS上创建一个名为/mydata/logs的目录,但是在/mydata目录下并没有logs子目录,则需要使用-p参数使得自动创建所需要的中间目录: hdfs dfs -mkdir -p /mydata/logs 在创建该命令时,程序会先判断/mydata是否存在,若不存在会创建该目录,接着程序会尝试创建一个名为logs的子目录,如果logs所在的/mydata目录不存在则会先创建该目录。 使用该命令在HDFS上创建目录时需要注意,运行该命令需要Hadoop集群的管理员权限和相关配置。此外,在创造HDFS目录时,应避免选择一个已经在使用的目录或文件名。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值