nyoj 999
nyoj 999: 点击打开题目链接
题目思路,处理一下地图,把 D E 能看到的地方标记一下。然后就是暴力广搜一下。标记状态,因为同样在同一个点,但是你刚出发到达那点和找到D之后到达相同的点和找到E之后到达相同的点,这3中状态是不同的。用vis[x][y][3]
来标记状态,标记状态知道这题就AC了。
还有另外的思路就是把它们一个一个搜,S-->D-->E S-->D-->E S-->D,E; 分别广搜,取min即可。
下面是第一种,标记状态的方法。另外一种就不写了。
#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<vector>
#include<string>
#include<string.h>
#include<queue> using namespace std;
typedef long long int LL;
typedef short int sint;
const int INF=~(1<<31);
const int MM=105; int n,m,times;
sint dir[4][2]= {{1,0},{0,1},{-1,0},{0,-1}};
char maps[MM][MM];
bool vis[MM][MM][3];
struct node
{
short int x,y,step,now;
};
bool is_out(sint x,sint y)
{
if(x>=0&&x<n&&y>=0&&y<m) return true;
return false;
}
int bfs(int sx,int sy)
{
node first,second;
if(maps[sx][sy]=='e') first.now=2;
else if(maps[sx][sy]=='d') first.now=1;
else if(maps[sx][sy]=='f') first.now=3;
else first.now=0;
queue<node>q;
first.step=0,first.x=(sint)sx,first.y=(sint)sy;
q.push(first);
while(!q.empty())
{
first=q.front();
q.pop();
// printf("step=%d x=%d y=%d now=%d\n",(int)first.step,first.x,first.y,first.now);
if(first.now==3) return first.step;
if(first.step>times) return -1;
for(int i=0; i<4; i++)
{
sint x=first.x+dir[i][0],y=first.y+dir[i][1];
if(is_out(x,y)&&vis[x][y][first.now]==0&&maps[x][y]!='X')
{
int now=first.now;
second.now=now;
vis[x][y][first.now]=true;
if(maps[x][y]=='f') second.now=3;
if(maps[x][y]=='d'&&now==2) second.now=3;
else if(maps[x][y]=='d') second.now=1;
if(maps[x][y]=='e'&&now==1) second.now=3;
else if(maps[x][y]=='e') second.now=2;
if(second.now!=3) vis[x][y][second.now]=true;
second.step=first.step+1,second.x=x,second.y=y;
q.push(second);
}
}
}
return -1;
}
void set_map(int dx,int dy,int ex,int ey)
{
int x,y;
for(x=dx+1,y=dy; is_out(x,y)&&maps[x][y]=='.'; x++) maps[x][y]='d';
for(x=dx-1,y=dy; is_out(x,y)&&maps[x][y]=='.'; x--) maps[x][y]='d';
for(x=dx,y=dy+1; is_out(x,y)&&maps[x][y]=='.'; y++) maps[x][y]='d';
for(x=dx,y=dy-1; is_out(x,y)&&maps[x][y]=='.'; y--) maps[x][y]='d'; for(x=ex+1,y=ey; is_out(x,y)&&(maps[x][y]=='.'||maps[x][y]=='d'); x++)
if(maps[x][y]=='d') maps[x][y]='f';
else maps[x][y]='e';
for(x=ex-1,y=ey; is_out(x,y)&&(maps[x][y]=='.'||maps[x][y]=='d'); x--)
if(maps[x][y]=='d') maps[x][y]='f';
else maps[x][y]='e';
for(x=ex,y=ey+1; is_out(x,y)&&(maps[x][y]=='.'||maps[x][y]=='d'); y++)
if(maps[x][y]=='d') maps[x][y]='f';
else maps[x][y]='e';
for(x=ex,y=ey-1; is_out(x,y)&&(maps[x][y]=='.'||maps[x][y]=='d'); y--)
if(maps[x][y]=='d') maps[x][y]='f';
else maps[x][y]='e';
}
void p_m()
{
int i,j;
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
printf("%c",maps[i][j]);
printf("\n");
}
}
int main(void)
{
int cases=0;
while(cin>>n>>m>>times)
{
int i,j,sx,sy,dx,dy,ex,ey;
memset(maps,0,sizeof(maps));
memset(vis,0,sizeof(vis));
for(i=0; i<n; i++)
{
cin>>maps[i];
for(j=0; j<m; j++)
{
if(maps[i][j]=='S') maps[i][j]='.',sx=i,sy=j;
if(maps[i][j]=='D') dx=i,dy=j;
if(maps[i][j]=='E') ex=i,ey=j;
}
}
set_map(dx,dy,ex,ey);
maps[dx][dy]='X';
maps[ex][ey]='X';
printf("Case %d:\n%d\n",++cases,bfs(sx,sy));
}
return 0;
}
nyoj 999的更多相关文章
- nyoj 999——师傅又被妖怪抓走了——————【双广搜】
师傅又被妖怪抓走了 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 话说唐僧复得了孙行者,师徒们一心同体,共诣西方.自宝象国救了公主,承君臣送出城西,沿路饥餐渴饮,悟 ...
- nyoj 163 Phone List(动态字典树<trie>) poj Phone List (静态字典树<trie>)
Phone List 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 Given a list of phone numbers, determine if it i ...
- NYOJ 1007
在博客NYOJ 998 中已经写过计算欧拉函数的三种方法,这里不再赘述. 本题也是对欧拉函数的应用的考查,不过考查了另外一个数论基本定理:如何用欧拉函数求小于n且与n互质所有的正整数的和. 记eule ...
- NYOJ 998
这道题是欧拉函数的使用,这里简要介绍下欧拉函数. 欧拉函数定义为:对于正整数n,欧拉函数是指不超过n且与n互质的正整数的个数. 欧拉函数的性质:1.设n = p1a1p2a2p3a3p4a4...pk ...
- Error Domain=NSURLErrorDomain Code=-999 “The operation couldn’t be completed.
转:http://www.wangzhengdong.com/blog/error-domainnsurlerrordomain-code-999-the-operation-couldnt-be-c ...
- NYOJ 333
http://www.cppblog.com/RyanWang/archive/2009/07/19/90512.aspx?opt=admin 欧拉函数 E(x)表示比x小的且与x互质的正整数的个数. ...
- NSURLErrorDomain -999 "Canceled" 错误探究
完整错误描述为 Error Domain=NSURLErrorDomain Code=-999 "Canceled/已取消" 这个错误一般用来描述某个网络请求在还未被发出时就被意外 ...
- NYOJ 99单词拼接(有向图的欧拉(回)路)
/* NYOJ 99单词拼接: 思路:欧拉回路或者欧拉路的搜索! 注意:是有向图的!不要当成无向图,否则在在搜索之前的判断中因为判断有无导致不必要的搜索,以致TLE! 有向图的欧拉路:abs(In[i ...
- 编写一个Java应用程序,该应用程序包括2个类:Print类和主类E。Print 类里有一个方法output()功能是输出100 ~ 999之间的所有水仙花数(各位数字的 立方和等于这个三位数本身,如: 371 = 33 + 73 + 13。)在主类E的main方法中来 测试类Print
package zuoye; public class print { void output() { System.out.println("100-999之间的水仙花数是:") ...
随机推荐
- Phantomjs和Casperjs,后台网页抓取和交互
var casper = require('casper').create({ verbose: true, logLevel: 'debug', pageSettings: { loadImages ...
- 代码布局relativeLayout
后台布局 在ANDROID 开发中有时候我们需要在后台添加布局文件这里我们来说一下后台添加RelativeLayout文件的方式: RelativeLayout,顾名思义,就是以“相对”位置/对齐 ...
- 小程序-地图API
摘要 地图组件-map 注意事项&&Bug: 1.map 组件是由客服端创建的原生组件,它的层级是最高的. 2.请勿在scroll-view中使用map组件 3.css动画对map组件 ...
- Codeforces 848B Rooter's Song(分类+模拟)
题目链接 Rooter's Song 题意 有n个舞者站在x轴上或y轴上,每个人有不同的出发时间.x轴上的舞者垂直x轴正方向移动,y轴上的舞者垂直y轴正方向移动. 当x轴的舞者和y轴的舞者相遇时,他 ...
- Codeforces 486D Valid Sets (树型DP)
题目链接 Valid Sets 题目要求我们在一棵树上计符合条件的连通块的个数. 满足该连通块内,点的权值极差小于等于d 树的点数满足 n <= 2000 首先我们先不管这个限制条件,也就是先考 ...
- codevs——2152 滑雪
2152 滑雪 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description trs喜欢滑雪.他来到了一个滑雪场,这个滑雪场 ...
- LCD1602和LCD12864
1602 字符型(字符型的模组) 只能显示数字与字符,不可以显示汉字 12864 点阵型(图形型的模组) 可根据需求任意显示字符 数字 汉字 图形 1602 为16字乘2行12864 为128列点阵乘 ...
- 64-bit Itanium与x64
64-bit Itanium是什么意思 64-bit Itanium,指的是intel 安腾处理器,intel安腾处理器是Intel的某一代处理器,当然是在酷睿(即core)这一代之前出来的. ora ...
- cocos2d-x 3.0 引用第三方库 及编译成apk时android mk文件写法
cocos2d-x 3.0 中.假设你须要使用CocosStudio.Extensions扩展库 等等.都须要自己手动加入. 加入过程例如以下:(比方说如今我要加入libExtensions,libC ...
- JAVA设计模式之单例模式(转)
本文继续介绍23种设计模式系列之单例模式. 概念: java中单例模式是一种常见的设计模式,单例模式的写法有好几种,这里主要介绍三种:懒汉式单例.饿汉式单例.登记式单例. 单例模式有以下特点: 1.单 ...