hdu1254(bfs+dfs)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1254
分析:
真正移动的是箱子,但是要移动箱子需要满足几个条件。
1.移动方向上没有障碍。
2.箱子后方没有障碍。
3.人可以到达箱子后方的地方。这里dfs或bfs都可以实现
按条件搜索即可。
#include <cstdio>
#include <cstring>
#include <cmath>
#include <iostream>
#include <algorithm>
#include <queue>
#include <cstdlib>
#include <stack>
#include <vector>
#include <set>
#include <map>
#define LL long long
#define mod 1000000007
#define inf 0x3f3f3f3f
#define N 100010
using namespace std;
typedef struct node
{
int Bx,By;
int Mx,My;
int step;
bool operator<(const node &a)const
{
return step>a.step;
}
}node;
int dx[]={,,,-};
int dy[]={,-,,};
int hash[][][][];
int vis[][],s[][];
int Bx,By,Mx,My,Nx,Ny;
int found,n,m;
node make_node(int a,int b,int x,int y)
{
node temp;
temp.Bx=a;temp.By=b;
temp.Mx=x;temp.My=y;
temp.step=;
return temp;
} int judge(int x,int y)
{
return x>=&&x<n&&y>=&&y<m&&s[x][y]!=;
}
void dfs(int Nx,int Ny,int Mx,int My)
{
if(Nx==Mx&&Ny==My)
{
found=;return;
}
for(int i=;i<&&!found;i++)
{
int x=Nx+dx[i];
int y=Ny+dy[i];
if(judge(x,y)&&!vis[x][y])
vis[x][y]=,dfs(x,y,Mx,My);
}
} void bfs(int Bx,int By,int Mx,int My)
{
priority_queue<node>que;
node p,q;
p=make_node(Bx,By,Mx,My);
que.push(p);
while(!que.empty())
{
node p=que.top();que.pop();
if(s[p.Bx][p.By]==)
{
printf("%d\n",p.step);return;
}
for(int i=;i<;i++)
{
q=p;
q.Bx=p.Bx+dx[i];//箱子移动的地方
q.By=p.By+dy[i];
Nx=p.Bx-dx[i];//箱子的后方
Ny=p.By-dy[i];
if(judge(q.Bx,q.By)&&judge(Nx,Ny)&&!hash[q.Bx][q.By][Nx][Ny])
{
memset(vis,,sizeof(vis));
vis[p.Bx][p.By]=vis[Nx][Ny]=;//注意这里箱子将成为阻碍物
found=;
dfs(Nx,Ny,p.Mx,p.My);//判断人是否可达箱子后面
if(found)
{
hash[q.Bx][q.By][Nx][Ny]=;
q.Mx=p.Bx;q.My=p.By;q.step++;
que.push(q);
}
}
}
}
printf("-1\n");
return;
}
void init()
{
memset(hash,,sizeof(hash));
memset(s,,sizeof(s));
for(int i=;i<n;i++)
for(int j=;j<m;j++)
{
scanf("%d",&s[i][j]);
if(s[i][j]==)
{
Bx=i;By=j;
}
if(s[i][j]==)
{
Mx=i;My=j;
}
}
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
init();
bfs(Bx,By,Mx,My);
}
}
hdu1254(bfs+dfs)的更多相关文章
- Cleaning Robot (bfs+dfs)
Cleaning Robot (bfs+dfs) Here, we want to solve path planning for a mobile robot cleaning a rectangu ...
- hdu 4771 求一点遍历全部给定点的最短路(bfs+dfs)
题目如题.题解如题. 因为目标点最多仅仅有4个,先bfs出俩俩最短路(包含起点).再dfs最短路.)0s1A;(当年弱跪杭州之题,现看如此简单) #include<iostream> #i ...
- HDU1254--推箱子(BFS+DFS)
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s) ...
- 图的基本遍历算法的实现(BFS & DFS)复习
#include <stdio.h> #define INF 32767 typedef struct MGraph{ ]; ][]; int ver_num, edge_num; }MG ...
- HDU 1044 Collect More Jewels(BFS+DFS)
Collect More Jewels Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...
- 图的遍历(bfs+dfs)模板
bfs #include<iostream> #include<queue> #include<cstdio> using namespace std; queue ...
- POJ-3083 Children of the Candy Corn (BFS+DFS)
Description The cornfield maze is a popular Halloween treat. Visitors are shown the entrance and mus ...
- POJ 3126 Prime Path(BFS算法)
思路:宽度优先搜索(BFS算法) #include<iostream> #include<stdio.h> #include<cmath> #include< ...
- Addition Chains POJ - 2248 (bfs / dfs / 迭代加深)
An addition chain for n is an integer sequence <a0, a1,a2,...,am=""> with the follow ...
随机推荐
- CF 8D Two Friends (三分+二分)
转载请注明出处,谢谢http://blog.csdn.net/ACM_cxlove?viewmode=contents by---cxlove 题意 :有三个点,p0,p1,p2.有两个人ali ...
- EF连接MySQL数据Web.Config配置
EF连接MySQL数据Web.Config配置 <?xml version="1.0" encoding="utf-8"?> <configu ...
- Android之一个简单计算器源代码
通过Android4.0 网格布局GridLayout来实现一个简单的计算器界面布局 源码如下(欢迎大家指导 批评 ) package com.android.xiong.gridlayoutTe ...
- 基于visual Studio2013解决C语言竞赛题之1059最大平台
题目 解决代码及点评 /* 功能:编写求最大平台问题的程序. 有n个整数a1,a2, ... an, 若满足a1≤a2≤ ... ≤ an , 则认为在这n个数中有最大平台.在这种情 ...
- 一点一滴完全突破KAZE特征检测算法,从各向异性扩散滤波开始(1)
ECCV2012中出现了一种比SIFT更稳定的特征检测算法KAZE.尽管,这个算法是几个法国人提出的,但是算法却有一个日文的名字.KAZE是日语‘风’的谐音,最近宣布退休的宫崎骏所拍摄的影片“起风了” ...
- 安装ipvsadm报错
server环境: [vagrant@localhost download]$ uname -a Linux RS1 2.6.18-238.el5 #1 SMP Thu Jan 13 15:51:15 ...
- NetBeans + Xdebug 调试WordPress
用NetBeans进行WordPress的相关开发和定制很顺手,配合Xdebug后调试起来也很方便. 详细配置过程如下(本例中Xampp安装目录为D:\xampp): 1: 下载xdebug(版本需匹 ...
- win2003的IIS無法使用,又一次安裝提示找不到iisadmin.mfl文件
我的系統是win2003 繁體版 sp2,現在iis無法使用,我同事的也是,也不知道是不是跟在網域中有關係,因為我用虛擬機的繁體系統win2003 R2版iis能够正常使用,不過曾经那台電腦也是在網域 ...
- vscode编写插件
vscode编写插件详细过程 前言 之前编写了一个vscode插件用vscode写博客和发布,然后有园友要求写一篇来介绍如何开发一个vscode扩展插件,或者说介绍开发这个插件的过程.然而文章还没有写 ...
- Qt之设置QWidget背景色(QStyleOption->drawPrimitive(QStyle::PE_Widget)方法比较有趣)
QWidget是所有用户界面对象的基类,这意味着可以用同样的方法为其它子类控件改变背景颜色. Qt中窗口背景的设置,下面介绍三种方法. 1.使用QPalette2.使用Style Sheet3.绘图事 ...