【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,一经查实,立即删除!

相关文章

P7077-函数调用【拓扑排序,dp】

正题 题目链接:https://www.luogu.com.cn/problem/P7077 题目大意 有一些函数分为三种 让一个位置的数加上一个数让所有数乘上一个数按顺序执行一些函数 然后不会有环&#xff0c;按顺序调用一些函数&#xff0c;求最后每个位置的数。 解题思路 我们发现对于一个乘操作其实…

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

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

Codeforces 1091E

Codeforces 1091E 题意&#xff1a;给定n个点的度数&#xff0c;请你添加第n1个点&#xff0c;输出所有可能的第n1个点的度数 做法&#xff1a;1. 查看链接知道了下面这个定理 A sequence of non-negative integers $ d_1\geq\cdots\geq d_n$ can be represented as the degree…

【每日一题】4月6日数码

题目&#xff1a;数码 来源&#xff1a;美团2017年CodeM大赛-资格赛 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 32768K&#xff0c;其他语言65536K 64bit IO Format:%lld 题目描述 给定两个整数 l 和 r &#xff0c;对于所有满足1 ≤ l ≤ …

【数学】异或(jzoj 2298)

异或 jzoj 2298 题目大意&#xff1a; 定义nbnbnb数对a,ba,ba,b为gcd(a,b)abgcd(a,b)a^bgcd(a,b)ab的数对&#xff0c;问不大于nnn的nbnbnb数对有多少对 输入样例#1 12输出样例#1 8输入样例#2 123456输出样例#2 214394数据范围 测试点数据规模11021003100045000510000…

Codeforces 235C

Codeforces 235C 题目&#xff1a;给定一主串\(S\)&#xff0c;\(n\)次询问&#xff0c;每次询问串\(t\)的所有循环移位串的出现的次数和 做法&#xff1a;建\(SAM\)&#xff0c;对于询问串\(t\)&#xff0c;将他复制一份放在后边&#xff0c;在后缀自动机上匹配&#xff0c;如…

Asp.Net Core实战

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

CF966E-May Holidays【虚树,分块】

正题 题目链接:https://codeforces.ml/contest/966/problem/E 题目大意 nnn个点的一棵树&#xff0c;每个点有一个tit_iti​&#xff0c;每次修改一个点是否为关键点&#xff0c;每次修改完后要求有多少个点满足该点不是关键点且子树中关键点数量超过tit_iti​。 解题思路 对…

DFS序讲解

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

纪中C组模拟赛总结(2019.8.9)

成绩&#xff1a; 注&#xff1a;rankrankrank是有算其他dalaodalaodalao的 rankrankranknamenamenamescorescorescoreT1T1T1T2T2T2T3T3T3T4T4T4111lyflyflyf250250250100100100100100100202020303030777hkyhkyhky200200200100100100100100100000000424242cyzcyzcyz1201201201…

虚树(Virtual Tree)学习笔记

虚树(Virtual Tree)学习笔记 一道题目(BZOJ-2286消耗战) Description 在一场战争中&#xff0c;战场由n个岛屿和n-1个桥梁组成&#xff0c;保证每两个岛屿间有且仅有一条路径可达。现在&#xff0c;我军已经侦查到敌军的总部在编号为1的岛屿&#xff0c;而且他们已经没有足够多…

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

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

P4284-[SHOI2014]概率充电器【树形dp,换根法,数学期望】

正题 题目链接:https://www.luogu.com.cn/problem/P4284 题目大意 nnn个点的一棵树&#xff0c;每个点有pip_ipi​概率通电&#xff0c;每个边有一定概率可以导电。求期望有电的节点个数。 解题思路 发现考虑通电概率很难&#xff0c;所以我们可以考虑不通电的概率。 如果只…

【每日一题】4月7日题目精讲 树

树 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 131072K 其他语言262144K 64bit IO Format:%lld 题目描述 shy有一颗树&#xff0c;树有n个结点。有k种不同颜色的染料给树染色。一个染色方案是合法的&#xff0c;当且仅当对于所有相同颜色的点…

【贪心】Radar Installation(poj 1328)

Radar Installation poj 1328 题目大意&#xff1a; 在平面直角坐标系的一二象限上有n个小岛&#xff0c;现在让你在x坐标上布置雷达&#xff0c;每个雷达可以侦测以它为原心&#xff0c;半径为m的圆内的所有小岛&#xff0c;现在问侦测完这n个小岛最少要多少个雷达 输入样…

HDU5765 Bonds (高维前缀和)

HDU5765 Bonds (高维前缀和) 题意&#xff1a;\(n(n<20)\)个点\(m\)条边无向图&#xff0c;求每条边出现在多少个\(Bond\)里。一个图的\(cut\)指&#xff0c;对于一个图\(G\)的边集的某个子集\(E\)&#xff0c;如果删除\(E\)中的所有边&#xff0c;原图不连通。一个图的\(Bo…

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

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

P4172-[WC2006]水管局长【LCT,最小生成树】

正题 题目链接:https://www.luogu.com.cn/problem/P4172 题目大意 nnn个点的一张图&#xff0c;有两个操作 询问两个点之间的一条路径使得最长边最短删除一条边 解题思路 显然这条边一定是在最小生成树上的&#xff0c;所以我们需要维护支持删边的最小生成树。 显然LCTLCTL…

牛客OI周赛15-普及组

1. 咪咪游戏 bool f1,f2,f; f1用于记录m f2用于记录q f用于判断串的好坏。1为坏&#xff0c;0为好 注意几种情况&#xff1a; mqm mmq 具体看代码&#xff1a; #include<bits/stdc.h> using namespace std; int main() {int n;cin>>n;string s;while(n--){bool f10…

【单调栈】向右看齐(luogu 2947)

向右看齐 luogu 2947 题目大意&#xff1a; 有n头奶牛&#xff0c;它们各有各的高度&#xff0c;现在要求出每一头奶牛右边第一头比他高的奶牛是那一头 输入样例 6 3 2 6 1 1 2 输出样例 3 3 0 6 6 0 输入说明 6 头奶牛的身高分别为 3, 2, 6, 1, 1, 2. 输出…