ytu 2463:给小鼠补充代码(DFS 深度优先搜索)
2463: 给小鼠补充代码
Time Limit: 2 Sec Memory Limit: 64 MB
Submit: 5 Solved: 2
[Submit][Status][Web Board]
Description
小鼠a与小鼠b身处一个m×n的迷宫中,如图所示。每一个方格表示迷宫中的一个房间。这m×n个房间中有一些房间是封闭的,不允许任何人进入。在迷宫中任何位置均可沿上,下,左,右4个方向进入未封闭的房间。小鼠a位于迷宫的(p,q)方格中,它必须找出一条通向小鼠b所在的(r,s)方格的路。请帮助小鼠a找出所有通向小鼠b的最短道路。
请编程对于给定的小鼠的迷宫,计算小鼠a通向小鼠b的所有最短道路。
//小鼠已经编好的代码如下,你只需要帮助小鼠实现dfp()函数即可,提交时也只需要提交dfp()函数的代码,其他代码会自动添加
//以下代码自动添加到程序开始
#include<stdio.h>
#include<memory.h>
#define INF 2100000000
#define MAX 100
int net[MAX][MAX];
bool isv[MAX][MAX];
int dx[4]= {1,0,-1,0};
int dy[4]= {0,1,0,-1};
int count,min,ct;
int curx,cury,endx,endy;
int col,row,num;
//需要帮助小鼠实现的代码
void dfp()
{
......
return ;
}
//以下代码自动添加到程序末尾
int main()
{
int i,x,y;
while(scanf("%d%d%d",&row,&col,&num)!=EOF)
{
memset(net,0,sizeof(net));
memset(isv,0,sizeof(isv));
min=INF;
count=0;
ct=0;
for(i=0; i<num; i++)
{
scanf("%d%d",&x,&y);
isv[x][y]=true;
}
scanf("%d%d%d%d",&curx,&cury,&endx,&endy);
dfp();
if(count==0) printf("No Solution!\n");
else
{
printf("%d\n%d\n",min,count);
}
}
return 0;
}
Input
本题有多组输入数据,你必须处理到EOF为止。 每组数据的第一行有3个正整数n,m,k,分别表示迷宫的行数,列数和封闭的房间数。接下来的k行中,每行2个正整数,表示被封闭的房间所在的行号和列号。最后的2行,每行也有2个正整数,分别表示小鼠a所处的方格(p,q)和小鼠b所处的方格(r,s)。
Output
对于每组数据,将计算出的小鼠a通向小鼠b的最短路长度和有多少条不同的最短路输出。每组数据输出两行,第一行是最短路长度;第2行是不同的最短路数。每组输出之间没有空行。 如果小鼠a无法通向小鼠b则输出“No Solution!”。
Sample Input
3 3
4 5
6 6
2 1
7 7
Sample Output
96
HINT
Source
#include<stdio.h>
#include<memory.h>
#define INF 2100000000
#define MAX 100
int net[MAX][MAX];
bool isv[MAX][MAX];
int dx[]= {,,-,};
int dy[]= {,,,-};
int count,min,ct;
int curx,cury,endx,endy;
int col,row,num; void dfp(){
if(ct>min) return;
if(curx<||cury<||curx>col||cury>row) return ;
if(curx==endx&&cury==endy){
if(min>ct){
count=;
min=ct;
}
else if(min==ct)
count++;
else return;
}
else{
for(int i=;i<=;i++){
curx+=dx[i];
cury+=dy[i];
ct++;
if(!isv[curx][cury]){
isv[curx][cury]=true;
dfp();
isv[curx][cury]=false;
}
ct--;
curx-=dx[i];
cury-=dy[i];
}
}
return ;
}
int main()
{
int i,x,y;
while(scanf("%d%d%d",&row,&col,&num)!=EOF)
{
memset(net,,sizeof(net));
memset(isv,,sizeof(isv));
min=INF;
count=;
ct=;
for(i=; i<num; i++)
{
scanf("%d%d",&x,&y);
isv[x][y]=true;
}
scanf("%d%d%d%d",&curx,&cury,&endx,&endy);
dfp();
if(count==) printf("No Solution!\n");
else
{
printf("%d\n%d\n",min,count);
}
}
return ;
} /**************************************************************
Problem: 2463
User: freecode
Language: C++
Result: Accepted
Time:4 ms
Memory:852 kb
****************************************************************/
Freecode : www.cnblogs.com/yym2013
ytu 2463:给小鼠补充代码(DFS 深度优先搜索)的更多相关文章
- ytu 1980:小鼠迷宫问题(DFS 深度优先搜索)
小鼠迷宫问题 Time Limit: 2 Sec Memory Limit: 64 MB Submit: 1 Solved: 1 [Submit][Status][Web Board] Desc ...
- 回溯算法 DFS深度优先搜索 (递归与非递归实现)
回溯法是一种选优搜索法(试探法),被称为通用的解题方法,这种方法适用于解一些组合数相当大的问题.通过剪枝(约束+限界)可以大幅减少解决问题的计算量(搜索量). 基本思想 将n元问题P的状态空间E表示成 ...
- HDU 1241 Oil Deposits DFS(深度优先搜索) 和 BFS(广度优先搜索)
Oil Deposits Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total ...
- HDU 4707 Pet(DFS(深度优先搜索)+BFS(广度优先搜索))
Pet Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissio ...
- 『ACM C++』HDU杭电OJ | 1416 - Gizilch (DFS - 深度优先搜索入门)
从周三课开始总算轻松了点,下午能在宿舍研究点题目啥的打一打,还好,刚开学的课程还算跟得上,刚开学的这些课程也是复习以前学过的知识,下半学期也不敢太划水了,被各种人寄予厚望之后瑟瑟发抖,只能努力前行了~ ...
- 步步为营(十五)搜索(一)DFS 深度优先搜索
前方大坑预警! 先讲讲什么是搜索吧. 有一天你去一个果园摘梨子,果农告诉你.有一棵树上有一个金子做的梨子,找到就是你的,你该怎么找? 地图例如以下: S 0 0 0 0 0 0 0 0 0 0 0 0 ...
- [算法总结]DFS(深度优先搜索)
目录 一.关于DFS 1. 什么是DFS 2. DFS的搜索方式 二.DFS的具体实现 三.剪枝 1. 顺序性剪枝 2. 重复性剪枝 3. 可行性剪枝 4. 最优性剪枝 5. 记忆化剪枝 四.练习 一 ...
- 回溯 DFS 深度优先搜索[待更新]
首先申明,本文根据微博博友 @JC向北 微博日志 整理得到,本文在这转载已经受作者授权! 1.概念 回溯算法 就是 如果这个节点不满足条件 (比如说已经被访问过了),就回到上一个节点尝试别 ...
- DFS——深度优先搜索的一般格式
DFS是一种深度优先的搜索思想,运用递归完成搜索,本质上也算是穷举思想的一类,可以通过剪枝进行优化. DFS的核心是回溯和递归, 如果以迷宫为例,一般会指定走各个方向的顺序(例如先左再上再右再下).从 ...
随机推荐
- Hadoop的datanode无法启动
Hadoop的datanode无法启动 hdfs-site中配置的dfs.data.dir为/usr/local/hadoop/hdfs/data 用bin/hadoop start-all.sh启动 ...
- serialization机制
首先说明一下序列化的知识: java中的序列化(serialization)机制能够将一个实例对象的状态信息写入到一个字节流中,使其可以通过socket进行传输.或者持久化存储到数据库或文件系统中:然 ...
- CSS打造经典鼠标触发显示选项
650) this.width=650;" border="0" alt="" src="http://img1.51cto.com/att ...
- ASP.NET MVC4中使用Ninject
1.NuGet获取Ninject.dll 选中项目右键: .NET技术交流群 199281001 .欢迎加入. 2.全局注册 Global.asax.cs //注册Ninject依赖注入全局解析器 ...
- Java开源数据库管理工具
SQuirreL SQL Client SQuirreL SQL Client 是一个用 Java 编写的程序,它允许您查看数据库的内容.发出 SQL 命令,以及如您将看到的,执行许多其他功能.构 ...
- 关于笔记本安装双系统windows and linux
ps1.安装完成后,补充下如何设在win7为默认启动系统, 大家也都知道,在linux 运行当软件都是以配置文件来设置参数当,当然grub菜单也不例外, 修改菜单可以进入grub.conf [root ...
- javascript和HTML5上传图片之前实现预览效果
一:FileList对象与file对象 FileList对象表示用户选择的文件列表,在HTML4中,file控件内只允许放置一个文件,但是到了HTML5中,通过添加multiple属性,file控件内 ...
- NPOI在.net中的操作Excel
1.读取 using (FileStream stream = new FileStream(@"c:\客户资料.xls", FileMode.Open, FileAccess.R ...
- 调用gluNurbsCurve绘制圆弧
<OpenGL编程指南>第12章第3小结专门介绍调用GLU绘制NURBS曲线或曲面,很可惜的是并未给出绘制圆弧的例子.网上可以找到很多绘制整个园的例子,却没圆弧例子,自己瞎折腾了2个礼拜, ...
- unity3d 参考坐标系
原地址:http://www.cnblogs.com/88999660/archive/2013/04/01/2993844.html 参考坐标系(Reference Coordinate Syste ...