ZOJ2018/4月月赛G题Traffic Light(广搜)


题意:首先T组数据,每组数据包括:第一行:一个n,m,然后下面有一个n行m列的01矩阵。
最后一行输入四个数字,分别是起点的横纵坐标,终点的横纵坐标。询问从起点到终点,最少要几步,如果到不了输出-1
题目给定要求:1、不能停在原地 2、如果当前点是0,那么只能走上下,如果当前点是1,只能走左右。3、每走一次,整个01矩阵反过来(0变成1,1变成0这样)
思路:注意到走2次就会变回原来的图,那么只需要分情况进行广搜即可,即:记录下当前点步数然后余2,就知道当前点是0还是1。然后再根据01的走动规则来入队列。
其次就是n和m很大,可以拿vector套vector存,也可以跟我一样拿map套pair存。
代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
map<pair<int,int>,int>ma;
map<pair<int,int>,int>vis;
int n,m;
struct note{
int x,y;
LL step;
}p,pos;
bool judge(int x,int y){
if(vis[make_pair(x,y)] == || x< || x>=n || y< || y>=m)
return false;
return true;
}//判断是否越界以及走过
int go[][]={{,-},{,},{,},{-,}};
LL bfs(int sx,int sy,int ex,int ey){
queue<note>q;
p.x = sx;
p.y = sy;
p.step = ;
q.push(p);
vis[make_pair(sx,sy)] = ;
while(!q.empty()){
pos = q.front();
q.pop();
//printf("ca %d %d %d\n",pos.x,pos.y,pos.step);
if(pos.x == ex && pos.y == ey) return pos.step;
int now = pos.step % ;//是否是原来的图
if(now == ){
if(ma[make_pair(pos.x,pos.y)] == ){
for(int i = ; i < ;i ++){
int dx = pos.x + go[i][];
int dy = pos.y + go[i][];
if(judge(dx,dy)){
vis[make_pair(dx,dy)] = ;
p.x = dx;
p.y = dy;
p.step = pos.step + ;
if(dx== ex && dy== ey)return p.step;
q.push(p);
}
}
}//如果当前是0
else{
for(int i = ; i < ;i ++){
int dx = pos.x + go[i][];
int dy = pos.y + go[i][];
if(judge(dx,dy)){
vis[make_pair(dx,dy)] = ;
p.x = dx;
p.y = dy;
p.step = pos.step + ;
if(dx== ex && dy== ey)return p.step;
q.push(p);
}
}
}
}
else if(now == ){
if(ma[make_pair(pos.x,pos.y)] == ){
for(int i = ; i < ;i ++){
int dx = pos.x + go[i][];
int dy = pos.y + go[i][];
if(judge(dx,dy)){
vis[make_pair(dx,dy)] = ;
p.x = dx;
p.y = dy;
p.step = pos.step + ;
if(dx== ex && dy== ey)return p.step;
q.push(p);
}
}
}//如果当前是1
else{
for(int i = ; i < ;i ++){
int dx = pos.x + go[i][];
int dy = pos.y + go[i][];
if(judge(dx,dy)){
vis[make_pair(dx,dy)] = ;
p.x = dx;
p.y = dy;
p.step = pos.step + ;
if(dx== ex && dy== ey) return p.step;
q.push(p);
}
}
}
}
}
return -*1LL;
}
int main(){
int t;
scanf("%d",&t);
while(t--){
int sx,sy,ex,ey;
scanf("%d %d",&n,&m);
for(int i = ; i < n ; i++){
for(int j = ; j < m ; j++){
int x;
scanf("%d",&x);
pair<int,int>pii = make_pair(i,j);
ma[pii] = x;
vis[pii] = ;
}
}
scanf("%d %d %d %d",&sx,&sy,&ex,&ey);
sx-=;sy-=;ex-=;ey-=;
printf("%d\n",bfs(sx,sy,ex,ey));
}
return ;
}
ZOJ2018/4月月赛G题Traffic Light(广搜)的更多相关文章
- csu 10月 月赛 H 题 A Very Hard Problem
Description CX老湿经常被人黑,被黑得多了,自己也就麻木了.于是经常听到有人黑他,他都会深情地说一句:禽兽啊! 一天CX老湿突发奇想,给大家出了一个难题,并且声称谁能够准确地回答出问题才能 ...
- csu 10月 月赛 I 题 The Contest
Description 殷犇有很多队员.他们都认为自己是最强的,于是,一场比赛开始了~ 于是安叔主办了一场比赛,比赛有n个题目,每个题目都有一个价值Pi和相对能力消耗Wi,但是有些题目因为太坑不能同时 ...
- csu 10月 月赛 D 题 CX and girls
Description CX是要赶去上课,为了不迟到必须要以最短的路径到达教室,同时CX希望经过的路上能看到的学妹越多越好.现在把地图抽象成一个无向图,CX从1点出发,教室在N号点,告诉每个点上学妹的 ...
- csu 10月 月赛 F 题 ZZY and his little friends
一道字典树异或的题,但是数据比较水,被大家用暴力给干掉了! 以前写过一个类似的题,叫做the longest xor in tree: 两个差不多吧! 好久没写字典树了,复习一下! 代码: #incl ...
- csu 10月 月赛 B 题 Scoop water
一个卡特兰数的应用: 卡特兰数主要有以下几个用途: 1.不同的出栈入栈数: 2.n个点组成的不同的二叉树的数目: 3.凸多边形的三角剖分划分: 4.括号化问题: 通项公式是:h(n) = C(2n-2 ...
- csu 10月 月赛 J 题
Description CSU又到了一年中评奖学金的时候了……各大学霸都或多或少地拿到了各种奖学金(你们自己看着办吧). 在这里,评奖学金有个很奇怪的规矩——每个同学得到的奖学金数一定满足相邻的两个非 ...
- CSU 2018年12月月赛 G(2219): Coin
Description 有这样一个众所周知的问题: 你面前有7个硬币,其中有一个劣质的(它比正常的硬币轻一点点),你有一个天平,问需要你需要使用天平多少次能保证找到那个劣质的硬币. 众所周知的算法是: ...
- Contest2037 - CSU Monthly 2013 Oct(中南大学2013年10月月赛水题部分题解)
Problem A: Small change 题解:http://www.cnblogs.com/crazyapple/p/3349469.html Problem B: Scoop water 题 ...
- csu 10月 月赛 A 题
Welcome to CSU OnlineJudge Problem A: Small change Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 15 ...
随机推荐
- docker资料转载
Docker之理解image,container和storage-driver centos7创建docker tomcat镜像 Linux Namespace和Cgroup
- 解析main函数的命令行参数
原创文章,转载请正确注明本文原始URL及作者. 介绍 写C/C++程序,我们常常需要把main函数的参数作为选项来传递.在linux中,解析选项有专门的函数可以用. int getopt(int ar ...
- webpack环境搭建
环境搭建参考:Webpack+vue+element逐步搭建开发环境 webpack入门:http://www.jianshu.com/p/42e11515c10f ----------------- ...
- Java设计模式——合成/聚合复用原则
一.什么是合成/聚合复用原则? 合成/聚合复用原则是在一个新的对象里面使用一些已有的对象,使之成为新对象的一部分:新的对象通过向这些对象的委派达到复用已有功能的目的. 简述为:要尽量使用合成/聚合,尽 ...
- Java 基础 - 对象池
对象池 优点: 防止过多的创建对象合理利用对象, 缺点: 会有线程阻塞 Demo 测试代码 package com.cjcx.pay.obj; import java.util.Enumerati ...
- Spring boot 启动配置原理
配置在META-INF/spring.factories 有几个主要的类 ApplicationContextInitializer 创建SpringAplication SpringAppli ...
- The Google File System——论文详解(转)
“Google文件存储系统(GFS)是构建在廉价服务器之上的大型分布式系统.它将服务器故障视为正常现象,通过软件方式自动容错,在保证系统可用性和可靠性同时,大大降低系统成本. GFS是Google整个 ...
- 尚硅谷springboot学习23-SpringMVC配置
1. Spring MVC auto-configuration 以下是SpringBoot对SpringMVC的默认配置:(WebMvcAutoConfiguration) Inclusion of ...
- cin.tie与sync_with_stdio加速输入输出
在LeetCode上练习习题的时候每次AC之后都会去看别人的代码,几乎每次都能遇到cin.tie与sync_with_stdio.类似这样: static auto x = [](){ std::io ...
- userdel删除用户失败提示:userdel: user * is currently logged in 解决方法
操作环境 SuSE10/SuSE11 问题现象 执行userdel -rf oracle删除用户失败,提示userdel: user 'oracle' is currently logged in ...