FOJ 1205
Problem 1205 小鼠迷宫问题
Accept: 522 Submit: 1679 Time Limit: 1000 mSec Memory Limit : 32768 KB
Problem Description
问题描述 小鼠a与小鼠b身处一个m×n的迷宫中,如图所示。每一个方格表示迷宫中的一个房间。这m×n个房间中有一些房间是封闭的,不允许任何人进入。在迷宫中任何位置均可沿上,下,左,右4个方向进入未封闭的房间。小鼠a位于迷宫的(p,q)方格中,它必须找出一条通向小鼠b所在的(r,s)方格的路。请帮助小鼠a找出所有通向小鼠b的最短道路。
小鼠的迷宫
编程任务
对于给定的小鼠的迷宫,编程计算小鼠a通向小鼠b的所有最短道路。
Input
结果输出
Output
Sample Input
Sample Output
Source
FJOI2005
- #include<stdio.h>
- #include<string.h>
- int sx[]={,,,-};
- int sy[]={,,-,};
- int map[][];
- int mark[][];
- int n,m;
- int x1,y1,x2,y2;
- int min_step,sum_min;
- int que[][];
- int que_step[];
- void bfs(int h,int l)
- {
- int front,rear;
- front=rear=;
- que[rear][]=h;
- que[rear][]=l;
- rear++;
- map[h][l]=;
- que_step[front]=;
- int xx,yy,i;
- while(front<rear)
- {
- for(i=;i<;i++)
- {
- xx=que[front][]+sx[i];
- yy=que[front][]+sy[i];
- if(xx==x2&&yy==y2)
- {
- min_step=que_step[front]+;
- return;
- }
- if(map[xx][yy]==&&xx<=n&&xx>=&&yy>=&&yy<=m)
- {
- //printf("(%d %d) step=%d\n",xx,yy,que_step[front]+1);
- que[rear][]=xx;
- que[rear][]=yy;
- que_step[rear]=que_step[front]+;
- rear++;
- map[xx][yy]=;
- }
- }
- front++;
- }
- }
- int t;
- void dfs(int x,int y,int c_step)
- {
- //printf("%d\n",c_step);
- if(x==x2&&y==y2&&c_step==min_step)
- {
- sum_min++; return ;
- }
- if((x>x2?x-x2:x2-x)+(y>y2?y-y2:y2-y)+c_step>min_step) return ;
- int i;
- for(i=;i<;i++)
- {
- int xx,yy;
- xx=x+sx[i];
- yy=y+sy[i];
- if(xx>=&&xx<=n&&yy>=&&yy<=m&&mark[xx][yy]==)
- {
- mark[xx][yy]=;
- dfs(xx,yy,c_step+);
- mark[xx][yy]=;
- }
- }
- }
- int main()
- {
- int k,i,j;
- while(scanf("%d %d %d",&n,&m,&k)!=EOF)
- {
- min_step=-;sum_min=;
- for(i=;i<=n;i++)
- {
- memset(map[i],,sizeof(map[i]));
- memset(mark[i],,sizeof(mark[i]));
- }
- for(i=;i<=k;i++)
- {
- int a,b;
- scanf("%d %d",&a,&b);
- map[a][b]=;
- mark[a][b]=;
- }
- scanf("%d %d %d %d",&x1,&y1,&x2,&y2);
- t=;
- bfs(x1,y1);
- if(min_step==-)
- printf("No Solution!\n");
- else
- {
- dfs(x1,y1,);
- printf("%d\n%d\n",min_step,sum_min);
- }
- }
- return ;
- }
- /*
- 3 3 1
- 2 2
- 1 1
- 3 3
- */
FOJ 1205的更多相关文章
- Caused by: java.sql.BatchUpdateException: Transaction error, need to rollback. errno:1205 Lock wait timeout exceeded; try restarting transaction
更新的时候报 Caused by: java.sql.BatchUpdateException: Transaction error, need to rollback. errno:1205 Loc ...
- Mysql Error:1205错误诊断
前两天遇到一个1205(ER_LOCK_WAIT_TIMEOUT)的错误,弄了半天终于找到原因,掌握原理+细心才能找到罪归祸首.下面我给大家分享下这个问题的分析处理过程,希望对大家有所帮助.接到sla ...
- 排序+逆向思维 ACdream 1205 Disappeared Block
题目传送门 /* 从大到小排序,逆向思维,从最后开始考虑,无后向性 每找到一个没被淹没的,对它左右的楼层查询是否它是孤立的,若是++,若不是-- 复杂度 O(n + m),还以为 O(n^2)吓得写了 ...
- Problem 2020 组合(FOJ)
Problem 2020 组合 Accept: 714 Submit: 1724Time Limit: 1000 mSec Memory Limit : 32768 KB Problem ...
- magento后台登陆被锁定 索引报错的解决:General error: 1205 Lock wait timeout
1. magento在索引的时候用shell,有时候会报错: General error: 1205 Lock wait timeout exceeded 这个时候,是因为行锁的原因,在表中您直接用s ...
- wikioi 1205 单词倒排
/*====================================================================== 1205 单词翻转 题目描述 Description ...
- ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
测试库一条update语句报错:ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction mysql> ...
- 九度OJ 1205 N阶楼梯上楼问题 -- 动态规划(递推求解)
题目地址:http://ac.jobdu.com/problem.php?pid=1205 题目描述: N阶楼梯上楼问题:一次可以走两阶或一阶,问有多少种上楼方式.(要求采用非递归) 输入: 输入包括 ...
- hdu 1205
#include <stdio.h> int a[1005000]; int main() { int t; scanf("%d",&t); while(t-- ...
随机推荐
- AngularJS - 快速入门
刚开始接触时总是去wiki或各种百科以了解一番. 它们会告诉我一些MVVM.双向数据绑定.依赖注入等等名词,觉得这些名词好上档次,然后我很可能就不打算用这个东西了. AngularJS是什么? 完全使 ...
- 配置个舒心的 Java 开发环境
Redmonk发布Java框架流行度调研结果:http://www.infoq.com/cn/news/2016/09/redmonk-java-frameworks 尝试:Intellij IDEA ...
- [转]java基础学习总结——equals方法
一.equals方法介绍 1.1.通过下面的例子掌握equals的用法 1 package cn.galc.test; 2 3 public class TestEquals { 4 public s ...
- 关闭浏览器后Session失效原因分析
参考文章:http://www.tuicool.com/articles/VNbYjqm 首先需要理解一下几点: 1.Http是无状态的,即对于每一次请求都是一个全新的请求,服务器不保存上一次请求的信 ...
- JS模式-基本的单例模式
//singleton var SingletonTester = (function(){ function Singleton(options){ options = options || {}; ...
- uva12532 线段树单点更新
#include<stdio.h> #include<string.h> #include<queue> using namespace std; #define ...
- BZOJ-1003 物流运输trans SPFA+DP
傻逼错误耗我1h,没给全范围坑我1A.... 1003: [ZJOI2006]物流运输trans Time Limit: 10 Sec Memory Limit: 162 MB Submit: 529 ...
- 【poj3714】 Raid
http://poj.org/problem?id=3714 (题目链接) 现在才搞平面最近点对..感觉有点尴尬 题意 给出平面上两组点,每组n个,求两组点之间最短距离 Solution1 平面最近点 ...
- BZOJ1208 宠物收养所
Description 最近,阿Q开了一间宠物收养所.收养所提供两种服务:收养被主人遗弃的宠物和让新的主人领养这些宠物.每个领养者都希望领养到自己满意的宠物,阿Q根据领养者的要求通过他自己发明的一个特 ...
- linux mysql 相关操作命令
1.linux下启动mysql的命令:mysqladmin start/ect/init.d/mysql start (前面为mysql的安装路径) 2.linux下重启mysql的命令:mysqla ...