HDU 1254 推箱子游戏(搞了一下午。。。)
中文题目:http://acm.hdu.edu.cn/showproblem.php?pid=1254
一开始常规的人用来做主导,想着想着不对劲,其实是箱子为主导,人只是箱子能否推进的一个判断。
可以使用两个BFS,人这里也可以DFS。看见别人有用四维标记的有用图中图的判重,我也用一下图中图好了。 #include<iostream>
#include<queue>
using namespace std; int n, m;
int map[10][10];
int vec[4][2] = {{-1,0}, {0,1}, {1,0}, {0,-1}};
int visited[10][10][4];//标记箱子。有四个方向,所有一个点可以推四次
int visitedP[10][10];//标记人 struct node
{
int x;
int y;
int step;
int innerMap[10][10];//保存每个点修改的图
bool check()
{
if(x>=0 && x<n && y>=0 && y<m)
return true;
return false;
}
}boxStart, peopleStart, peopleEnd, target; int PeopleBFS(node t)
{
peopleStart = t;
memset(visitedP, 0, sizeof(visitedP)); queue<node> Q;
//找人的位置
for (int i = 0; i<n; i++)
{
for (int j = 0; j<m; j++)
{
if (t.innerMap[i][j] == 4)
{
peopleStart.x = i;
peopleStart.y = j;
peopleStart.step = 0;
}
}
}
if(peopleStart.x == peopleEnd.x && peopleStart.y == peopleEnd.y)
return true;
visitedP[peopleStart.x][peopleStart.y] = true; Q.push(peopleStart);
while (!Q.empty())
{
node q = Q.front();
Q.pop();
for (int i = 0; i<4; i++)
{
node p = q;
p.x += vec[i][0];
p.y += vec[i][1];
p.step++;
if (p.check() && !visitedP[p.x][p.y] && t.innerMap[p.x][p.y]!=1
&& t.innerMap[p.x][p.y]!= 2)//不是墙不是箱
{
visitedP[p.x][p.y] = true;
if (p.x == peopleEnd.x && p.y == peopleEnd.y)//可以到
{
return true;
}
Q.push(p);
}
}
}
return false;
} int BoxBFS()
{
queue<node> Q;
Q.push(boxStart);
while (!Q.empty())
{
node q = Q.front();
Q.pop();
for (int i = 0; i<4; i++)
{
node p = q;
p.x += vec[i][0];
p.y += vec[i][1];
p.step++;
if (p.check() && !visited[p.x][p.y][i] && map[p.x][p.y] != 1)
{
//找出人站在箱子前进方向的反方向
peopleEnd = q;
peopleEnd.x = q.x - vec[i][0];
peopleEnd.y = q.y - vec[i][1];
if (peopleEnd.check())//人可以站在这个位置
{
if (PeopleBFS(peopleEnd))//人可以到达 {
swap(p.innerMap[p.x][p.y], p.innerMap[q.x][q.y]);//箱子走一步
swap(p.innerMap[peopleEnd.x][peopleEnd.y],
p.innerMap[peopleStart.x][peopleStart.y]);//人跟上
visited[p.x][p.y][i] = true;
if (map[p.x][p.y] == 3)//到达目的地
{
return p.step;
}
Q.push(p); }
}
}
}
}
return -1;
} int main()
{
int T;
cin>>T;
while (T--)
{
cin>>n>>m;
memset(visited, 0, sizeof(visited));
for (int i = 0; i<n; i++)
{
for (int j = 0; j<m; j++)
{
cin>>map[i][j];
boxStart.innerMap[i][j] = map[i][j];
if (map[i][j] == 2)//箱子起始
{
boxStart.x = i;
boxStart.y = j;
boxStart.step = 0;
}
}
}
cout<<BoxBFS()<<endl;
}
return 0;
}
HDU 1254 推箱子游戏(搞了一下午。。。)的更多相关文章
- HDU 1254 推箱子(BFS加优先队列)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1254 推箱子 Time Limit: 2000/1000 MS (Java/Others) Me ...
- HDU 1254 推箱子 BFS
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1254 题目分析: 做这道题,感觉挺简单的,做着做着就错了20次, 我也是醉了, WA到吐的节奏啊! 思 ...
- hdu 1254 推箱子(搜索)
我写的第一道感觉比较难的搜索 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1254 首先要推箱子的话要满足人能够在箱子旁边,而且人的对面也是可通的. ...
- hdu - 1254 推箱子 (bfs+bfs)
http://acm.hdu.edu.cn/showproblem.php?pid=1254 题目意思很简单,只要思路对就好. 首先考虑搬运工能否到达推箱子的那个点,这个可以根据箱子前进方向得出搬运工 ...
- hdu.1254.推箱子(bfs + 优先队列)
推箱子 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...
- [HDU 1254] 推箱子
推箱子 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...
- HDU 1254 推箱子(BFS)
Problem Description 推箱子是一个很经典的游戏.今天我们来玩一个简单版本.在一个M*N的房间里有一个箱子和一个搬运工,搬运工的工作就是把箱子推到指定的位置,注意,搬运工只能推箱子而不 ...
- hdu 1254 推箱子(双重bfs)
题目链接 Problem Description 推箱子是一个很经典的游戏.今天我们来玩一个简单版本.在一个M*N的房间里有一个箱子和一个搬运工,搬运工的工作就是把箱子推到指定的位置,注意,搬运工只能 ...
- hdu 1254 推箱子(嵌套搜索,bfs中有dfs)
推箱子 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...
随机推荐
- Source Insight使用技巧
1. source insight必设: option-->key assignments--> Edit: Delete Line ---- Assign New Key: Ctr ...
- BZOJ 3039: 玉蟾宫( 悬线法 )
最大子矩阵...悬线法..时间复杂度O(nm) 悬线法就是记录一个H向上延伸的最大长度(悬线), L, R向左向右延伸的最大长度, 然后通过递推来得到. ----------------------- ...
- 高级UIKit-03(NSFileManager、NSFileHandle)
fileManager文件管理器 [day04_1_FileManager_Search] :查找文件 fileManager有一个方法可以判断文件是否是文件夹, fileExistsAtPath:i ...
- 基于visual Studio2013解决C语言竞赛题之0704字符串长度
题目
- android intent收集转载汇总
Intent intent = new Intent(Settings.ACTION_WIRELESS_SETTINGS); ComponentName comp = ...
- C#:总结页面传值几种方法
小知识点: 1. W7自带 .NetFrameWork 3.5, 兼容模式为 高版本号兼容低版本号: 2. WF和WPF都是基于XAML的,可是两者的用途不同. WF是一种开发框架,将工作流嵌入在. ...
- CSS实现强制换行-------Day 78
事实上最早的时候也考虑过这个问题,当时还在想须要判定文字的长度么,实在是傻到极点了,原来CSS中本来就有这个样式设置的.而今天正好看到了有这么一篇介绍.细致看了下,感觉还不错,这里也把实验的结果记录下 ...
- log4net使用流程
前面大致介绍了一下log4net的概述和结构.既然都清楚了,下面我来介绍一下如何使用log4net. 使用流程 1.这里所说的使用流程就是使用log4net.dll,首先要根据你的平台来找出对应的版本 ...
- Android UI 之WaterFall瀑布流效果
所谓瀑布流效果,简单说就是宽度相同但是高度不同的一大堆图片,分成几列,然后像水流一样向下排列,并随着用户的上下滑动自动加载更多的图片内容. 语言描述比较抽象,具体效果看下面的截图: ...
- Bee Framework_百度百科
Bee Framework_百度百科 Bee Framework 编辑 目录 1详细信息 简介 特性 2工作 主要模块 编译要求 运行要求 目录结构 运行例程 安装步骤 1详细信息 简介 ...