HDOJ(HDU).1035 Robot Motion (DFS)
HDOJ(HDU).1035 Robot Motion [从零开始DFS(4)]
从零开始DFS
HDOJ.1342 Lotto [从零开始DFS(0)] — DFS思想与框架/双重DFS
HDOJ.1010 Tempter of the Bone [从零开始DFS(1)] —DFS四向搜索/奇偶剪枝
HDOJ(HDU).1015 Safecracker [从零开始DFS(2)] —DFS四向搜索变种
HDOJ(HDU).1016 Prime Ring Problem (DFS) [从零开始DFS(3)] —小结:做DFS题目的关注点
HDOJ(HDU).1035 Robot Motion [从零开始DFS(4)]—DFS题目练习
HDOJ(HDU).1241 Oil Deposits(DFS) [从零开始DFS(5)] —DFS八向搜索/双重for循环遍历
HDOJ(HDU).1258 Sum It Up (DFS) [从零开始DFS(6)] —DFS双重搜索/去重技巧
HDOJ(HDU).1045 Fire Net [从零开始DFS(7)]—DFS练习/check函数的思想
题意分析
给出地图规模n * m, 给出入口坐标(0,y),遵循以下规则,求解机器人能否走出地图。若能,输出走出地图所需要的步数,若不能,输出进入循环前走的步数和循环的步数。
规则:
若当前格子为N,则只能向上走,若为S向下走,E向右走,W向左走。
我第一感觉是模拟题,因为对于每个格子状态是唯一的,只有1组解:要么能走出去,要么不能。分别求出步数就行了,但感觉dfs能做,决定还是按照dfs的方法试一试。
分析一波:
递归边界就是机器人走出了地图或者是机器人走回到了走过的地方(吃回头草了),即可判定输出了。那么需要记录的东西就是当前走的步数,和循环的步数。当前走的步数好说,递归传参+1就行了,循环的步数想想也不难:当下一步就要吃回头草的时候,两个状态的步数之差就是循环的步数。与先前的双重搜索,四向搜索不同,dfs中要判断这个格子的字符是什么,然后决定如何走下一步。
上代码。
代码总览
/*
Title:HDOJ.1035
Author:pengwill
Date:2017-2-6
*/
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
int n,m,y,loop,step,beloop;
char mp[11][11];
int visit[11][11];
bool judge = false;
bool check(int x, int y)
{
if(x<0||x>=n||y<0||y>=m){ judge = true ;return false;}
else return true;
}
void dfs(int x, int y, int s)
{
if(!check(x,y)) return;
step = s;
if(!judge){
if(!visit[x][y]){
visit[x][y] = s;
if(mp[x][y] == 'N') dfs(x-1,y,s+1);
else if(mp[x][y] == 'S') dfs(x+1,y,s+1);
else if(mp[x][y] == 'E') dfs(x,y+1,s+1);
else if(mp[x][y] == 'W') dfs(x,y-1,s+1);
}else{
beloop = visit[x][y]-1;
loop = s - visit[x][y] ;
}
}
}
int main()
{
// 难点如何记步
//freopen("in.txt","r",stdin);
while(scanf("%d%d",&n,&m)&&n){
scanf("%d",&y);y--;
for(int i = 0;i<n;++i)
scanf("%s",mp[i]);
judge = false;
memset(visit,0,sizeof(visit));
dfs(0,y,1);
if(judge) printf("%d step(s) to exit\n",step);
else printf("%d step(s) before a loop of %d step(s)\n",beloop,loop);
}
return 0;
}
首先有3个全局变量保存着结果,分别是step,loop,beloop,分别保存着走出地图用的步数,循环的步数,在循环之前的步数。
main函数完成初始化,check函数检查是否走出地图,若走出地图则judge置为true并且终止递归。每一步把当前的步数保存在visit[x][y]中,并且根据visit[x][y]是否为0判断是否吃了“回头草”。最后别忘了及时更新loop和beloop。
应该来说是一道简单的dfs应用题。
从零开始DFS:
HDOJ.1342 Lotto [从零开始DFS(0)]
HDOJ.1010 Tempter of the Bone [从零开始DFS(1)]
HDOJ(HDU).1015 Safecracker [从零开始DFS(2)]
HDOJ(HDU).1015 Safecracker [从零开始DFS(3)]
HDOJ(HDU).1035 Robot Motion (DFS)的更多相关文章
- hdu 1035 Robot Motion(dfs)
虽然做出来了,还是很失望的!!! 加油!!!还是慢慢来吧!!! >>>>>>>>>>>>>>>>> ...
- (step 4.3.5)hdu 1035(Robot Motion——DFS)
题目大意:输入三个整数n,m,k,分别表示在接下来有一个n行m列的地图.一个机器人从第一行的第k列进入.问机器人经过多少步才能出来.如果出现了循环 则输出循环的步数 解题思路:DFS 代码如下(有详细 ...
- [ACM] hdu 1035 Robot Motion (模拟或DFS)
Robot Motion Problem Description A robot has been programmed to follow the instructions in its path. ...
- HDU 1035 Robot Motion(dfs + 模拟)
嗯... 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1035 这道题比较简单,但自己一直被卡,原因就是在读入mp这张字符图的时候用了scanf被卡. ...
- 题解报告:hdu 1035 Robot Motion(简单搜索一遍)
Problem Description A robot has been programmed to follow the instructions in its path. Instructions ...
- hdu 1035 Robot Motion(模拟)
Problem Description A robot has been programmed to follow the instructions in its path. Instructions ...
- HDOJ(HDU).1045 Fire Net (DFS)
HDOJ(HDU).1045 Fire Net [从零开始DFS(7)] 点我挑战题目 从零开始DFS HDOJ.1342 Lotto [从零开始DFS(0)] - DFS思想与框架/双重DFS HD ...
- HDOJ(HDU).1241 Oil Deposits(DFS)
HDOJ(HDU).1241 Oil Deposits(DFS) [从零开始DFS(5)] 点我挑战题目 从零开始DFS HDOJ.1342 Lotto [从零开始DFS(0)] - DFS思想与框架 ...
- HDOJ(HDU).2660 Accepted Necklace (DFS)
HDOJ(HDU).2660 Accepted Necklace (DFS) 点我挑战题目 题意分析 给出一些石头,这些石头都有自身的价值和重量.现在要求从这些石头中选K个石头,求出重量不超过W的这些 ...
随机推荐
- focus如何实现事件委托
事件委托是利用事件冒泡机制的一种优化手段,如果有很多列表元素要绑定事件,那么就可以用事件委托来优化(不需要给每个元素都绑定事件).但是对于focus这种特殊的表单事件,它不会冒泡,那么又该如何实现这一 ...
- 软件测试工程师必备的SQL语句基础
为一个软件测试工程师,我们在测试过程中往往需要对数据库数据进行操作,但是我们的操作大多以查询居多,有时会涉及到新增,修改,删除等操作,所以我们其实并不需要对数据库的操作有特别深入的了解,以下是我在工作 ...
- Win10系统XWware虚拟机安装Linux系统(Ubuntu)最新版教程
XWware虚拟机安装Linux系统(Ubuntu)教程 一.下载并安装VMware虚拟机 借助VMware Workstation Pro, 我们可以在同一台Windows或Linux PC上同时运 ...
- SQL学习(时间,存储过程,触发器)
SQL学习 几个操作时间的函数 --datapart 获取时间中的年月日时分秒等部分 select DATEPART(year,current_timestamp); select DATEPART( ...
- vue中如何实现pdf文件预览?
今天产品提出一个优化的需求,就是之前我们做的图片展示就是一个img标签搞定,由于我们做的是海外后台管理系统,那边的人上传的文件时pdf格式,vue本事是不支持这种格式文件展示的,于是就google搜索 ...
- hdu刷题1
1002 大数加法 #include<iostream> #include<cstring> using namespace std; int main() { ],b[]; ...
- spring java config 初探
Java Config 注解 spring java config作为同xml配置形式的另一种表达形式,使用的场景越来越多,在新版本的spring boot中 大量使用,今天我们来看下用到的主要注解有 ...
- Bitcoin: A Peer-to-Peer Electronic Cash System
Bitcoin: A Peer-to-Peer Electronic Cash System Satoshi Nakamoto October 31, 2008 Abstract A purely p ...
- ThinkPHP - 4 - 学习笔记(2015.4.12)
ThinkPHP D方法 D方法用于实例化自定义模型类,是ThinkPHP框架对Model类实例化的一种封装,并实现了单例模式,支持跨项目和分组调用,调用格式如下:D('[项目://][分组/]模型' ...
- maven 教程二 深入
一:编写POM <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w ...