hdu1428漫步校园( 最短路+BFS(优先队列)+记忆化搜索(DFS))
1 2 3
1 2 3
1 2 3
3
1 1 1
1 1 1
1 1 1
6
#include<stdio.h>
#include<iostream>
#include<queue>
using namespace std;
typedef struct nn
{
int dist,x,y;
friend bool operator <(nn n1,nn n2)
{
return n1.dist>n2.dist;
}
}node;
int map[55][55],N[55][55],n;
__int64 dp[55][55];
int dir[4][2]={1,0,-1,0,0,1,0,-1};
void BFS()//求每一点到终点的最小距离,从终点出发
{
priority_queue<node> Q;
node q,p;
int i,tx,ty;
q.x=q.y=n; q.dist=map[n][n];
Q.push(q); N[n][n]=map[n][n];
while(!Q.empty())
{
q=Q.top();
Q.pop();
for(i=0;i<4;i++)
{
tx=q.x+dir[i][1];ty=q.y+dir[i][0];
if(tx>0&&tx<=n&&ty>0&&ty<=n)
if(N[ty][tx]==-1||N[ty][tx]>N[q.y][q.x]+map[ty][tx])//当前点还没有用过或是用过了又不是最小距离,才执行
{
p.x=tx;p.y=ty; p.dist=N[q.y][q.x]+map[ty][tx];
N[ty][tx]=p.dist;
Q.push(p);
}
}
}//printf("%d",N[1][1]);
}
__int64 DFS(int x,int y)//记忆化搜索,每点到终点满足条件有多少种走法
{
int e,tx,ty;
if(dp[y][x]>0)//当前的点己经走过了,直接反回当前的点有多少种走法
return dp[y][x];
if(x==n&&y==n)
return 1;
for(e=0;e<4;e++)//当前点所走的范围,所以会把它所有范围的点到终点的走法全加起来
{
tx=x+dir[e][1];ty=y+dir[e][0];
if(ty>0&&ty<=n&&tx>0&&tx<=n)
if(N[y][x]>N[ty][tx])//当前的点到终点距离要大于它将要走的点到终点的距离,有多少种走法
{
dp[y][x]+=DFS(tx,ty);
}
}
return dp[y][x];//当前点的范围走完时,反回给它所在其他点的范围
}
int main()
{
int i,j;
__int64 k;
while(scanf("%d",&n)>0)
{
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
{
scanf("%d",&map[i][j]);
N[i][j]=-1;dp[i][j]=0;
}
BFS();
/*for(i=1;i<=n;i++)
{printf("\n");
for(j=1;j<=n;j++)
printf("%d ",N[i][j]); }*/
k=DFS(1,1);
printf("%I64d\n",k);
}
}
hdu1428漫步校园( 最短路+BFS(优先队列)+记忆化搜索(DFS))的更多相关文章
- HDU 1428 漫步校园 (BFS+优先队列+记忆化搜索)
题目地址:HDU 1428 先用BFS+优先队列求出全部点到机房的最短距离.然后用记忆化搜索去搜. 代码例如以下: #include <iostream> #include <str ...
- HDU 1142 A Walk Through the Forest(SPFA+记忆化搜索DFS)
题目链接 题意 :办公室编号为1,家编号为2,问从办公室到家有多少条路径,当然路径要短,从A走到B的条件是,A到家比B到家要远,所以可以从A走向B . 思路 : 先以终点为起点求最短路,然后记忆化搜索 ...
- 记忆化搜索(DFS+DP) URAL 1223 Chernobyl’ Eagle on a Roof
题目传送门 /* 记忆化搜索(DFS+DP):dp[x][y] 表示x个蛋,在y楼扔后所需要的实验次数 ans = min (ans, max (dp[x][y-i], dp[x-1][i-1]) + ...
- 记忆化搜索(DFS+DP) URAL 1501 Sense of Beauty
题目传送门 /* 题意:给了两堆牌,每次从首部取出一张牌,按颜色分配到两个新堆,分配过程两新堆的总数差不大于1 记忆化搜索(DFS+DP):我们思考如果我们将连续的两个操作看成一个集体操作,那么这个操 ...
- 【BZOJ】1415: [Noi2005]聪聪和可可【期望】【最短路】【记忆化搜索】
1415: [Noi2005]聪聪和可可 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2335 Solved: 1373[Submit][Stat ...
- 【洛谷】3953:逛公园【反向最短路】【记忆化搜索(DP)统计方案】
P3953 逛公园 题目描述 策策同学特别喜欢逛公园.公园可以看成一张N个点M条边构成的有向图,且没有 自环和重边.其中1号点是公园的入口,N号点是公园的出口,每条边有一个非负权值, 代表策策经过这条 ...
- hdu1978How many ways (记忆化搜索+DFS)
Problem Description 这是一个简单的生存游戏,你控制一个机器人从一个棋盘的起始点(1,1)走到棋盘的终点(n,m).游戏的规则描述如下: 1.机器人一开始在棋盘的起始点并有起始点所标 ...
- P2921 [USACO08DEC]在农场万圣节Trick or Treat on the Farm 记忆化搜索dfs
题目描述 每年,在威斯康星州,奶牛们都会穿上衣服,收集农夫约翰在N(1<=N<=100,000)个牛棚隔间中留下的糖果,以此来庆祝美国秋天的万圣节. 由于牛棚不太大,FJ通过指定奶牛必须遵 ...
- 洛谷 P1141【BFS】+记忆化搜索+染色
题目链接:https://www.luogu.org/problemnew/show/P1141 题目描述 有一个仅由数字 0 与 1 组成的n×n 格迷宫.若你位于一格0上,那么你可以移动到相邻 4 ...
随机推荐
- Linux 中直接 I/O 机制的介绍
https://www.ibm.com/developerworks/cn/linux/l-cn-directio/ 对于传统的操作系统来说,普通的 I/O 操作一般会被内核缓存,这种 I/O 被称作 ...
- 浅谈Linux容器和镜像签名
导读 从根本上说,几乎所有的主要软件,即使是开源软件,都是在基于镜像的容器技术出现之前设计的.这意味着把软件放到容器中相当于是一次平台移植.这也意味着一些程序可以很容易就迁移,而另一些就更困难. 我大 ...
- [Everyday Mathematics]20150107
设 $f\in C^1[a,b]$, $f(a)=0$, 且存在 $\lm>0$, 使得 $$\bex |f'(x)|\leq \lm |f(x)|,\quad \forall\ x\in [a ...
- Devexpress GridControl z
http://minmin86121.blog.163.com/blog/static/4968115720144194923578/ 1 AllowNullInput=False; --Devexp ...
- IOS CAShapeLayer CAGradientLayer UIBezierPath 使用实例
CGRect rect = CGRectMake(100, 100, 100, 100); UIView * bgView = [[UIView alloc]initWithFrame:rect]; ...
- 《Python 学习手册4th》 第十五章 文档
''' 时间: 9月5日 - 9月30日 要求: 1. 书本内容总结归纳,整理在博客园笔记上传 2. 完成所有课后习题 注:“#” 后加的是备注内容 (每天看42页内容,可以保证月底看完此书) “重点 ...
- 用javascript 面向对象制作坦克大战(二)
2. 完善地图 我们的地图中有空地,墙,钢,草丛,水,总部等障碍物. 我们可以把这些全部设计为对象. 2.1 创建障碍物对象群 对象群保存各种地图上的对象,我们通过对象的属性来判断对 ...
- 读《编写高质量代码-Web前端开发修炼之道》笔记
第一章 1.Web标准由一系列标准组合而成,核心理念是将网页的结构,样式和行为分离,所以分为三大部分:结构标准,样式标准和行为标准.结构标准包括XML标准,XHTML标准,HTML标准:样式标准指CS ...
- C++ 之高效使用STL ( STL 算法分类)
http://blog.csdn.net/zhoukuo1981/article/details/3452118
- 《APUE》中的函数整理
第1章 unix基础知识 1. char *strerror(int errnum) 该函数将errnum(就是errno值)映射为一个出错信息字符串,返回该字符串指针.声明在string.h文件中. ...