Find a way (BFS)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2612
BFS搜索 目标地 并记录下来 之后再判断两段路程之和
代码:
#include <stdio.h>
#include <string.h>
#include <math.h>
#include <algorithm>
#include <iostream>
#include <ctype.h>
#include <iomanip>
#include <queue>
#include <stdlib.h>
using namespace std; #define INF 0x3f3f3f3f
#define N 220
#define M 220
int n,m;
char mp[N][M];
int vis1[N][M],vis2[N][M];
int ans1[N][M],ans2[N][M];
int dx[]={,,,-};
int dy[]={,-,,}; struct node
{
int x,y;
int t;
}; node g1,g2;
void getMp()
{
for(int i=; i<n; i++){
for(int j=; j<m; j++){
cin>>mp[i][j];
if(mp[i][j]=='Y'){
g1.x=i;
g1.y=j;
g1.t=;
vis1[i][j]=;
}
if(mp[i][j]=='M'){
g2.x=i;
g2.y=j;
g2.t=;
vis2[i][j]=;
}
}
}
} void bfs1()
{
queue<node> q;
while(!q.empty())
q.pop();
q.push(g1);
while(!q.empty()){
node f1;
f1=q.front();
q.pop();
for(int i=; i<; i++){
node f2;
f2.x=f1.x+dx[i];
f2.y=f1.y+dy[i];
f2.t=f1.t;
if(<=f2.x&&f2.x<n&&<=f2.y&&f2.y<m&&!vis1[f2.x][f2.y]&&mp[f2.x][f2.y]!='#'){
f2.t++;
if(mp[f2.x][f2.y]=='@'){
ans1[f2.x][f2.y]=f2.t;
}
vis1[f2.x][f2.y]=;
q.push(f2);
}
}
}
} void bfs2()
{
queue<node> q;
while(!q.empty())
q.pop();
q.push(g2);
while(!q.empty()){
node f1;
f1=q.front();
q.pop();
for(int i=; i<; i++){
node f2;
f2.x=f1.x+dx[i];
f2.y=f1.y+dy[i];
f2.t=f1.t;
if(<=f2.x&&f2.x<n&&<=f2.y&&f2.y<m&&!vis2[f2.x][f2.y]&&mp[f2.x][f2.y]!='#'){
f2.t++;
if(mp[f2.x][f2.y]=='@'){
ans2[f2.x][f2.y]=f2.t;
}
vis2[f2.x][f2.y]=;
q.push(f2);
}
}
}
} int main()
{
while(~scanf("%d %d",&n,&m)){
memset(ans1,-,sizeof(ans1));
memset(ans2,-,sizeof(ans2));
memset(vis1,,sizeof(vis1));
memset(vis2,,sizeof(vis2));
getMp();
bfs1();
bfs2();
int min=INF;
for(int i=;i<n;i++)
for(int j=;j<m;j++)
{
if(ans1[i][j]+ans2[i][j]<min&&ans1[i][j]+ans2[i][j]>)
{
min=ans1[i][j]+ans2[i][j];
}
}
printf("%d\n",min*);
}
}
Find a way (BFS)的更多相关文章
- 图的遍历(搜索)算法(深度优先算法DFS和广度优先算法BFS)
图的遍历的定义: 从图的某个顶点出发访问遍图中所有顶点,且每个顶点仅被访问一次.(连通图与非连通图) 深度优先遍历(DFS): 1.访问指定的起始顶点: 2.若当前访问的顶点的邻接顶点有未被访问的,则 ...
- 【BZOJ-1656】The Grove 树木 BFS + 射线法
1656: [Usaco2006 Jan] The Grove 树木 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 186 Solved: 118[Su ...
- POJ 3278 Catch That Cow(bfs)
传送门 Catch That Cow Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 80273 Accepted: 25 ...
- POJ 2251 Dungeon Master(3D迷宫 bfs)
传送门 Dungeon Master Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 28416 Accepted: 11 ...
- Sicily 1215: 脱离地牢(BFS)
这道题按照题意直接BFS即可,主要要注意题意中的相遇是指两种情况:一种是同时到达同一格子,另一种是在移动时相遇,如Paris在(1,2),而Helen在(1,2),若下一步Paris到达(1,1),而 ...
- Sicily 1048: Inverso(BFS)
题意是给出一个3*3的黑白网格,每点击其中一格就会使某些格子的颜色发生转变,求达到目标状态网格的操作.可用BFS搜索解答,用vector储存每次的操作 #include<bits/stdc++. ...
- Sicily 1444: Prime Path(BFS)
题意为给出两个四位素数A.B,每次只能对A的某一位数字进行修改,使它成为另一个四位的素数,问最少经过多少操作,能使A变到B.可以直接进行BFS搜索 #include<bits/stdc++.h& ...
- Sicily 1051: 魔板(BFS+排重)
相对1150题来说,这道题的N可能超过10,所以需要进行排重,即相同状态的魔板不要重复压倒队列里,这里我用map储存操作过的状态,也可以用康托编码来储存状态,这样时间缩短为0.03秒.关于康托展开可以 ...
- Sicily 1150: 简单魔板(BFS)
此题可以使用BFS进行解答,使用8位的十进制数来储存魔板的状态,用BFS进行搜索即可 #include <bits/stdc++.h> using namespace std; int o ...
- ACM/ICPC 之 靠墙走-DFS+BFS(POJ3083)
//POJ3083 //DFS求靠左墙(右墙)走的路径长+BFS求最短路 //Time:0Ms Memory:716K #include<iostream> #include<cst ...
随机推荐
- 插入排序java
插入排序简述 插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的.个数加一的有序数据. 第一个元素是有序队列,从第二个元素开始向有序队列中插入,插入完成后将第三个元素向 ...
- Sliverlight实例之 绘制扇形和环形图
一,1道几何题 已知两点坐标确定一条直线,直线上存在一个未知点,起始点与未知点的距离已知 求:未知点坐标 思路,如下: 求AB长度,可以根据两点距离公式 二,写个C#类 定义一个Point类,代表坐标 ...
- 【C语言探索之旅】 第二部分第十课:练习题和习作
内容简介 1.课程大纲 2.第二部分第十一课: 练习题和习作 3.第三部分第一课预告: 安装SDL 课程大纲 我们的课程分为四大部分,每一个部分结束后都会有练习题,并会公布答案.还会带大家用C语言 ...
- Android Application Thread CPU GC Operatiing and OOM Question 0603-随手笔记
面前app当完成测试,没问题,以完成整个老龄化阶段包含数据收发器,关键在 adb shell top -m 5 我发现我的 app pid 占用 CPU是最多的,事实上我想说写一个app是不难,你 ...
- HTML基本介绍
html 即 超文本标记语言 ,即标准通用标记语言下的一个应用. "超文本"就是指页面内能够包括图片.链接.甚至音乐.程序等非文字元素.超文本标记语言的结构包括"头&qu ...
- 玩转Web之Json(一)-----easy ui+ajax + json 中关于Json的解析问题
在easy ui中使用Ajax+Json实现前后的数据交互时,当后台数据传输到客户端是需对Json数据进行解析,这里将对Json数据解析做简单总结. (一) 对于服务器返回的数据若没有做类型说明,需要 ...
- Android - 分享内容 - 给其他APP发送内容
创建一个intent时,必须要指定intent将要触发的操作.Android定义了很多操作,包括ACTION_SEND,就象可以猜到的一样,表示intent是把数据从一个activity发送给另一个, ...
- Codeforces 437E The Child and Polygon(间隔DP)
题目链接:Codeforces 437E The Child and Polygon 题目大意:给出一个多边形,问说有多少种切割方法.将多边形切割为多个三角形. 解题思路:首先要理解向量叉积的性质,一 ...
- 使用autoconf和automake生成Makefile文件(转)
Makefile好难写 曾经也总结了一篇关于Makefile的文章<make和makefile的简单学习>.但是,总结完以后,发现写Makefile真的是一件非常痛苦的事情,的确非常痛苦. ...
- EasyUI DataGrid和Pagination
连接一台EasyUI项目驱动学习 DataGrid数据表格及Pagination分页一起介绍 一.通过<table>标记创建DataGrid,嵌套<th>标签定义列表 < ...