【bfs】神殿(jzoj 2296)

神殿

jzoj 2296

题目大意:

用一个n∗mn*mnm的矩阵,每个单位都是一个1∗11*111的房间,房间的四个方向只有某些方向有门(说明如下图),要从一个房间走向相邻的房间(算一个单位时间)必须要他们中间的两个门都是存在,也可以把所有房间的门顺时针旋转一轮(算一个单位时间),现在问从(x1,y1)(x_1,y_1)(x1,y1)走到(x2,y2)(x_2,y_2)(x2,y2)最少需要多少各单位时间
在这里插入图片描述

输入样例#1

2 2
+*
*U
1 1 2 2

输出样例#1

-1

输入样例#2

2 3
<><
><>
1 1 2 1

输出样例#2

4

数据范围

对于30%的数据,满足n,m⩽10n,m \leqslant 10n,m10
对于50%的数据,满足n,m⩽50n,m \leqslant 50n,m50
对于另外20%的数据,满足没一个房间要么只有一个方向没门,要么一个方向上的门都没有。
对于100%的数据,满足n,m⩽1000n,m \leqslant 1000n,m1000

题目标中的特殊符号:

<>^v+*|-

解题思路:

直接bfs去跑,每一次要么旋转,要么走,这样时间复杂度就是o(4nm)o(4nm)o(4nm)(整个图加上旋转的四种情况)

代码:

#include<queue> 
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
const int dx[4]={-1,0,1,0};
const int dy[4]={0,-1,0,1};
int n,m,x1,x2,y1,y2,a[1500][1500][5],p[1500][1500][5];
char x;
struct rec
{int x,y,r,num;
};
void input()//输入
{scanf("%d %d",&n,&m);for (int i=1;i<=n;++i){getchar();for (int j=1;j<=m;++j){x=getchar();if (x=='+') a[i][j][0]=1,a[i][j][1]=1,a[i][j][2]=1,a[i][j][3]=1;//判断每一种情况else if (x=='-') a[i][j][1]=1,a[i][j][3]=1;else if (x=='|') a[i][j][0]=1,a[i][j][2]=1;else if (x=='^') a[i][j][0]=1;else if (x=='>') a[i][j][3]=1;else if (x=='<') a[i][j][1]=1;else if (x=='v') a[i][j][2]=1;else if (x=='L') a[i][j][0]=1,a[i][j][2]=1,a[i][j][3]=1;else if (x=='R') a[i][j][0]=1,a[i][j][1]=1,a[i][j][2]=1;else if (x=='U') a[i][j][1]=1,a[i][j][2]=1,a[i][j][3]=1;else if (x=='D') a[i][j][0]=1,a[i][j][1]=1,a[i][j][3]=1;}}scanf("%d %d %d %d",&x1,&y1,&x2,&y2);
}
bool check(rec gg,int f)
{if (!p[gg.x+dx[f]][gg.y+dy[f]][gg.r])//判断是否到过if (a[gg.x][gg.y][(f+gg.r)%4] && a[gg.x+dx[f]][gg.y+dy[f]][(f+gg.r+2)%4])//判断是否两道门都开if(gg.x+dx[f]>0 && gg.x+dx[f]<=n && gg.y+dy[f]>0 && gg.y+dy[f]<=m)//判断是否超界return true;return false;
}
void bfs()
{queue<rec>d;rec o;o.x=x1;o.y=y1;o.num=0;//时间o.r=0;//旋转次数d.push(o);p[x1][y1][0]=1;if (o.x==x2&&o.y==y2){printf("0");return;}while(!d.empty()){rec h=d.front();d.pop();if (!p[h.x][h.y][(h.r+1)%4])//旋转{rec o;o.x=h.x;o.y=h.y;o.num=h.num+1;o.r=(h.r+1)%4;p[o.x][o.y][o.r]=1;d.push(o);}for (int i=0;i<4;++i)//往某个方向走if (check(h,i)){rec o;o.x=h.x+dx[i];o.y=h.y+dy[i];o.r=h.r;o.num=h.num+1;p[o.x][o.y][o.r]=1;d.push(o);if (o.x==x2&&o.y==y2){printf("%d",o.num);return;}}}printf("-1");
}
int main()
{input();bfs();
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320461.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何在本地数据中心安装Service Fabric for Windows集群

概述首先本文只是对官方文档&#xff08;中文&#xff0c;英文&#xff09;的一个提炼&#xff0c;详细的安装说明还请仔细阅读官方文档。虽然Service Fabric的官方名称往往被加上Azure&#xff0c;但是实际上&#xff08;估计很多人不知道&#xff09;Service Fabric可以安装到…

Asp.Net Core实战

序言使用.NET Core&#xff0c;团队可以更容易专注的在.net core上工作。比如核心类库&#xff08;如System.Collections&#xff09;的更改仍然需要与.NET Framework相同的活力&#xff0c;但是ASP.NET Core或Entity Framework Core可以更轻松地进行实质性更改&#xff0c;而不…

DFS序讲解

我们经常会遇到树的问题&#xff0c;但树是非线性的结构&#xff0c;操作起来始终还是麻烦&#xff0c;如果我们能把树改造成线性结构&#xff0c;有什么方法&#xff1f;对&#xff0c;就是今天要讲的DSF序&#xff1b; dfs序呢&#xff0c;就是把一棵树区间化&#xff0c;我们…

利用Asp.Net Core的MiddleWare思想处理复杂业务流程

最近利用Asp.Net Core 的MiddleWare思想对公司的古老代码进行重构&#xff0c;在这里把我的设计思路分享出来&#xff0c;希望对大家处理复杂的流程业务能有所帮助。背景一个流程初始化接口&#xff0c;接口中根据传入的流程类型&#xff0c;需要做一些不同的工作。1.有的工作是…

F# 4.5提供Spans、Match!等特性

F# 4.5预览版现已发布&#xff0c;其中提供了一系列新特性&#xff0c;包括对.NET Core 2.1的新原生类型Span<T>的支持、新关键字Match!等。类型Span意在实现底层代码指针操作的安全性和可预测性&#xff0c;这可使得很多情况下不必再分配内存&#xff0c;进而改进了内存…

Abp + Grpc 如何实现用户会话状态传递

0.背景在实际项目当中&#xff0c;我采用的是 Abp 框架&#xff0c;但是 Abp 框架官方并没有针对 Grpc 进行模块封装。基于此我结合 Abp 与 MagicOnion 封装了一个 Abp.Grpc 模块&#xff0c;它包括服务端和调用端两部分的包。通过这两个包&#xff0c;你可以很方便地在 Abp 框…

恢复数列

题目链接 比赛链接 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K Special Judge,64bit IO Format: %lld 题目描述 小y的数学作业不小心被泼上了墨水。有道题看不清了&#xff0c;现在他想请你帮他恢复这道…

【翻译】asp.net core中使用MediatR

这篇文章来自&#xff1a;https://ardalis.com/using-mediatr-in-aspnet-core-apps本文作为翻译&#xff0c;有一些单词翻译成中文可能会有一些误解&#xff08;对于读者&#xff09;或者错误&#xff08;对于作者&#xff09;的地方&#xff0c;所以在文章中你可以看到一些单词…

数论杂谈(欧拉定理与费马小定理结论与应用)

文章目录欧拉定理&#xff1a;欧拉定理性质&#xff1a;扩展欧拉定理&#xff1a;费马小定理&#xff1a;指数循环节费马大定理逆元&#xff1a;例题原根定义&#xff1a;原根存在条件例题快速幂代码矩阵快速幂原理&#xff1a;代码&#xff1a;欧拉定理&#xff1a; aφ(n)≡…

ASP.NET Core MVC with EF Core-迁移

当你开发一个新的应用程序的时候&#xff0c;你的模型频繁的变化&#xff0c;而每一次的数据模型的改变&#xff0c;将使它与数据库不同步。你通过配置EF Core&#xff0c;使得数据库不存在时创建数据库。每一次改变数据模型&#xff08;增删改 实体类或者改变DbContextClass),…

C#中字段、属性、只读、构造函数赋值、反射赋值的相关

C#中字段、属性和构造函数赋值的问题提出问题首先提出几个问题&#xff1a;1、如何实现自己的注入框架&#xff1f;2、字段和自动属性的区别是什么&#xff1f;3、字段和自动属性声明时的直接赋值和构造函数赋值有什么区别&#xff1f;4、为什么只读字段和只读自动属性&#xf…

.NET Core开发日志——RequestDelegate

本文主要是对.NET Core开发日志——Middleware的补遗&#xff0c;但是会从看起来平平无奇的RequestDelegate开始叙述&#xff0c;所以以其作为标题&#xff0c;也是合情合理。RequestDelegate是一种委托类型&#xff0c;其全貌为public delegate Task RequestDelegate(HttpCont…

[SDOI2008]仪仗队

牛客网 题目描述 作为体育委员&#xff0c;C君负责这次运动会仪仗队的训练。 仪仗队是由学生组成的N * N的方阵&#xff0c;为了保证队伍在行进中整齐划一&#xff0c;C君会跟在仪仗队的左后方&#xff0c;根据其视线所及的学生人数来判断队伍是否整齐(如下图)。 现在&#xff…

.NetCore SkyWalking APM实现服务器监控环境安装及基础使用

下载Java 8 SDK wget --no-cookies --no-check-certificate --header "Cookie: gpw_e24http%3A%2F%2Fwww.oracle.com%2F; oraclelicenseaccept-securebackup-cookie" http://download.oracle.com/otn-pub/java/jdk/8u171-b11/512cd62ec5174c3487ac17c61aaa89e8/jdk…

ASP.NET Core依赖注入最佳实践,提示技巧

分享翻译一篇Abp框架作者(Halil İbrahim Kalkan)关于ASP.NET Core依赖注入的博文.在本文中,我将分享我在ASP.NET Core应用程序中使用依赖注入的经验和建议.这些原则背后的目的是:有效地设计服务及其依赖关系防止多线程问题防止内存泄漏防止潜在的错误本文假设你已经熟悉基本的…

Maximize The Beautiful Value

传送 时间限制&#xff1a;C/C 2秒&#xff0c;其他语言4秒 空间限制&#xff1a;C/C 131072K&#xff0c;其他语言262144K 64bit IO Format:%lld 题目描述 Today HH finds a non-decreasing sequence(a1,a2…an,ai≤ai1), he thinks it’s not beautiful so he wants to make …

MEF 插件式开发 - DotNetCore 初体验

背景叙述在传统的基于 .Net Framework 框架下进行的 MEF 开发&#xff0c;大多是使用 MEF 1&#xff0c;对应的命名空间是 System.ComponentModel.Composition。在 DotNet Core 中&#xff0c;微软为了伟大的跨平台策略&#xff0c;引入了 MEF 2&#xff0c;其对应的命名空间是…

反向传播算法学习笔记

反向传播算法(Back propagation) 目的及思想 我们现在有一堆输入&#xff0c;我们希望能有一个网络&#xff0c;使得通过这个网络的构成的映射关系满足我们的期待。也就是说&#xff0c;我们在解决这个问题之前先假设&#xff0c;这种映射可以用网络的模型来比较好的描述。为什…

求树的直径

欢迎来踩本人博客 树的直径&#xff1a; 就是树上最长路 方法 &#xff1a; 求两边DFS即可 步骤&#xff1a; 1.从任意一点进行dfs&#xff0c;然后找到一个最长路径&#xff0c;记录最远点u 2.然后从u再进行dfs&#xff0c;找最长路径&#xff0c;记录一点v。 &#xff08;u&…

微软技术直通车(第三期) 之 人工智能

编者&#xff1a;有幸本周在北京&#xff0c;大家有空来现场面基。微软技术直通车本系列活动密切关注微软及周边相关技术。以微软云计算和相关产品为依托&#xff0c;涉及云计算、数据处理、开发工具、商用软件、物联网、人工智能等前沿科技。系列活动邀请微软技术专家、一线开…