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

8 8 3
3 3
4 5
6 6
2 1
7 7

Sample Output

11
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 深度优先搜索)的更多相关文章

  1. ytu 1980:小鼠迷宫问题(DFS 深度优先搜索)

     小鼠迷宫问题 Time Limit: 2 Sec  Memory Limit: 64 MB Submit: 1  Solved: 1 [Submit][Status][Web Board] Desc ...

  2. 回溯算法 DFS深度优先搜索 (递归与非递归实现)

    回溯法是一种选优搜索法(试探法),被称为通用的解题方法,这种方法适用于解一些组合数相当大的问题.通过剪枝(约束+限界)可以大幅减少解决问题的计算量(搜索量). 基本思想 将n元问题P的状态空间E表示成 ...

  3. HDU 1241 Oil Deposits DFS(深度优先搜索) 和 BFS(广度优先搜索)

    Oil Deposits Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total ...

  4. HDU 4707 Pet(DFS(深度优先搜索)+BFS(广度优先搜索))

    Pet Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissio ...

  5. 『ACM C++』HDU杭电OJ | 1416 - Gizilch (DFS - 深度优先搜索入门)

    从周三课开始总算轻松了点,下午能在宿舍研究点题目啥的打一打,还好,刚开学的课程还算跟得上,刚开学的这些课程也是复习以前学过的知识,下半学期也不敢太划水了,被各种人寄予厚望之后瑟瑟发抖,只能努力前行了~ ...

  6. 步步为营(十五)搜索(一)DFS 深度优先搜索

    前方大坑预警! 先讲讲什么是搜索吧. 有一天你去一个果园摘梨子,果农告诉你.有一棵树上有一个金子做的梨子,找到就是你的,你该怎么找? 地图例如以下: S 0 0 0 0 0 0 0 0 0 0 0 0 ...

  7. [算法总结]DFS(深度优先搜索)

    目录 一.关于DFS 1. 什么是DFS 2. DFS的搜索方式 二.DFS的具体实现 三.剪枝 1. 顺序性剪枝 2. 重复性剪枝 3. 可行性剪枝 4. 最优性剪枝 5. 记忆化剪枝 四.练习 一 ...

  8. 回溯 DFS 深度优先搜索[待更新]

      首先申明,本文根据微博博友 @JC向北 微博日志 整理得到,本文在这转载已经受作者授权!   1.概念   回溯算法 就是 如果这个节点不满足条件 (比如说已经被访问过了),就回到上一个节点尝试别 ...

  9. DFS——深度优先搜索的一般格式

    DFS是一种深度优先的搜索思想,运用递归完成搜索,本质上也算是穷举思想的一类,可以通过剪枝进行优化. DFS的核心是回溯和递归, 如果以迷宫为例,一般会指定走各个方向的顺序(例如先左再上再右再下).从 ...

随机推荐

  1. 未能正确加载“Microsoft.VisualStudio.Editor.Implementation.EditorPackage,

    未能正确加载“Microsoft.VisualStudio.Editor.Implementation.EditorPackage, Microsoft.VisualStudio.Editor.Imp ...

  2. 如何查看ubuntu下显卡驱动是否已经成功安装

    首先得安装mesa-utils,在终端输入命令:sudo apt-get install mesa-utils然后再运行命令:glxinfo | grep rendering如果结果是“yes”,证明 ...

  3. Matlab之findobj()

    findobj findobj:特殊属性的图形对象 语法: 1.findobj: findobj返回根对象的句柄和所有子对象(findobj returns handles of the root o ...

  4. iOS 用instancetype代替id作返回类型有什么好处?

    2014-07-07更新:苹果在iOS 8中全面使用instancetype代替id Steven Fisher:只要一个类返回自身的实例,用instancetype就有好处. @interface ...

  5. iOS 时间处理(转)

    NSDate NSDate对象用来表示一个具体的时间点. NSDate是一个类簇,我们所使用的NSDate对象,都是NSDate的私有子类的实体. NSDate存储的是GMT时间,使用的时候会根据 当 ...

  6. Spring各个jar包的简介

    spring.jar是包含有完整发布的单个jar 包,spring.jar中包含除了spring-mock.jar里所包含的内容外其它所有jar包的内容,因为只有在开发环境下才会用到 spring-m ...

  7. ZeroMQ(java)之Router与Dealer运行原理

    在开始这部分的内容之前,先来看看ZeroMQ中HWM概念---High-Water Marks 当系统的数据量很大,而且发送频率很高的情况下,内存就很重要了,如果处理不好会出现很多问题,例如如下场景: ...

  8. javascript对象转化为基本数据类型规则

    原文:Object-to-Primitive Conversions in JavaScript 对象转化为基础数据类型,其实最终都是用调用对象自带的valueOf和toString两个方法之一并获得 ...

  9. BZOJ 2818

    2818:GCD Description 给定整数$N$,求$1\le x,y\le N$且$\gcd{x,y}$为素数的数对$(x,y)$有多少对. Input $N$ Output RT Samp ...

  10. 【云计算】开源装机自动化系统 CloudBoot OSInstall 介绍

    "CloudBoot"(OSinstall) 发布了. 产品更新及特点如下: 新增虚拟化操作系统适配:支持主流操作系统:RedHat.CentOS.SUSE.Ubuntu.Wind ...