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-- ...
随机推荐
- jQuery使用之(二)设置元素的样式
css是页面不能分隔的部分,jQuery中也提供了一些css相关的实用的办法.前面章节中有使用过 addClass()为元素添加css样式风格.本节主要介绍jQuery如何设置页面的样式风格.包括添加 ...
- linux 安装webbench
webbench :1.5 http://soft.vpser.net/test/webbench/webbench-1.5.tar.gz从官网下载webbench-1.5.tar.gz1.解压 t ...
- 每天一个linux命令(11):less 命令
less 工 具也是对文件或其它输出进行分页显示的工具,应该说是linux正统查看文件内容的工具,功能极其强大.less 的用法比起 more 更加的有弹性. 在 more 的时候,我们并没有办法向前 ...
- ibatis中的$和#的区别
介绍 在Ibatis中我们使用SqlMap进行Sql查询时需要引用参数,在参数引用中遇到的符号#和$之间的区分为,#可以进行与编译,进行类型匹配,而$不进行数据类型匹配,例如: select * fr ...
- 【CodeForces 471A】MUH and Sticks
题 题意 给你六根木棍的长度,熊需要头比身体短,大象需要头和身体一样,四肢要一样长,否则就是外星人.请你判断能组成哪一个. 分析 暴力,循环看一下每根有几根相同的,然后如果有四根都是有四根相同的&am ...
- 【CodeForces 577B】Modulo Sum
题 题意 给你n(1 ≤ n ≤ 106)个数a1..an(0 ≤ ai ≤ 109),再给你m( 2 ≤ m ≤ 103)如果n个数的子集的和可以被m整除,则输出YES,否则NO. 分析 分两种情况 ...
- 【CSU 1556】Pseudoprime numbers
题 Description Jerry is caught by Tom. He was penned up in one room with a door, which only can be op ...
- BZOJ-2049 Cave洞穴勘测 动态树Link-Cut-Tree (并查集骗分TAT)
2049: [Sdoi2008]Cave 洞穴勘测 Time Limit: 10 Sec Memory Limit: 259 MB Submit: 5833 Solved: 2666 [Submit] ...
- 【bzoj2115】 Xor
www.lydsy.com/JudgeOnline/problem.php?id=2115 (题目链接) 题意 给出一张图,可能有重边和自环,在图中找出一条从1-n的路径,使得经过的路径的权值的异或和 ...
- 点击div区域以外部分,div区域隐藏
核心思想: 监听body的click事件,事件触发的时候判断是否发生在弹出的div上,如果不在,关闭弹层 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTM ...