Jelly

Jelly

https://ac.nowcoder.com/acm/contest/5338/A

链接:

时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K,其他语言262144K
64bit IO Format:%lld

题目描述

Nancy喜欢吃果冻! Nancy钻进了一个n \times n \times
nn×n×n的果冻里,她想从(1,1,1)一路上、下、左、右、前、后六个方向吃到(n,n,n)。
但果冻毕竟是有许多口味的,标记为*的口味是Nancy不愿意吃的,其余的果冻均标记为.。 Nancy不想吃坏肚子,于是她想尽可能少的吃果冻。
下面给出果冻的情况,请你帮忙计算一下她能吃多少块果冻叭!

输入描述:

第一行:一个整数n。 接下来n层,每组n行,每行n列,表示果冻(i,j,k)的情况(如题目描述所述)。

数据满足:1≤n≤100,保证果冻(1,1,1)不是Nancy不愿意吃的。
输出描述:
如果可以到达(n,n,n),请输出路上吃的果冻数量,否则请输出-1。
示例1
输入

2
.*
..
*.
..

输出

4

题解:
三维版dfs
方向向量:
int dx[]={0,1,0,-1,0,0};
int dy[]={1,0,-1,0,0,0};
int dz[]={0,0,0,0,1,-1};
dis用于记录步数
for循环枚举方向向量,从(1,1,1)开始分别向上、下、左、右、前、后六个方向探索,如果不是 * 就加一
最后输出dis[n][n][n]
代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn=104;
char a[maxn][maxn][maxn];

int dx[]={0,1,0,-1,0,0};
int dy[]={1,0,-1,0,0,0};
int dz[]={0,0,0,0,1,-1};
struct edge{
    int x,y,z;
};
queue<edge>q;
int dis[maxn][maxn][maxn];

int main()
{
    int n;
    cin>>n;
    char ch=getchar();
    for(int i=1;i<=n;i++)
    {
            for(int j=1;j<=n;j++)
        {
            for(int k=1;k<=n;k++)
            {
                cin>>a[i][j][k];
            }
            ch=getchar(); 
        }
    }
    if(a[n][n][n]=='*')
    {
        cout<<-1;
        return 0;
    }
    q.push((edge){1,1,1});
    dis[1][1][1]=1;
    while(!q.empty())
    {
        edge now=q.front();
        q.pop();
        int x,y,z;
        for(int i=0;i<6;i++)
        {
            x=now.x+dx[i];
            y=now.y+dy[i];
            z=now.z+dz[i];
            if(x&&y&&z&&x<=n&&y<=n&&z<=n&&a[x][y][z]!='*'&&dis[x][y][z]==0)
            {
                dis[x][y][z]=dis[now.x][now.y][now.z]+1;
                q.push((edge){x,y,z});
            }
        }
    }
    cout<<dis[n][n][n];

} 
全部评论

相关推荐

头像
03-14 11:23
已编辑
北京邮电大学 管理咨询
211勇闯初创小公司头破血流系列3这件事不是发生在我身上的,但前同事们参与创作的积极性空前高涨,为了习惯,还是都采用第一人称的视角来看这出大戏。有一天老板在我们的眼皮底下接了一个电话,最终敲定了去北京出差的时间,下周一。他得意洋洋地说,这单下来保底五百万的流水,如果成了,我们都能得到五位数的提成。这对于一群刚上班的人来说是天大的诱惑,我们经历了周末的无偿加班,把他去北京所需要的文件都准备好了。只是在去北京的周一当天,老板睡过头了。整个上午都没见他的踪影,给他发文件也不会,打电话问问题也不接,直到中午才姗姗来迟。当然,这只是拉开了这场恐怖出差的序幕。只见他来了也不紧不慢的,手指在办公室转了一圈,...
姜大力:补充: 1.五百万的单子根本没有五百万,只是过去展示拼装的产品并简单考察。该项目只是竞标,项目内容是商业街区改造; 2.决策是当天上午10点半左右老板珊珊来迟后突发奇想去北京,中午1点在催促下着急出发,没有任何出差补助; 3.出发之前已经知道进京证不好使了,但还是执意要开车去; 4.实习生实打实连续开了***小事车,非常辛苦,工资在转正后只有两千五; (有疑问会继续补充)
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务