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 ...
随机推荐
- ASP.NET 经典60道面试题
转:http://bbs.chinaunix.net/thread-4065577-1-1.html ASP.NET 经典60道面试题 1. 简述 private. protected. public ...
- HDU 5783 Divide the Sequence
Divide the Sequence Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Othe ...
- POJ 3067 Japan
Japan Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 25489 Accepted: 6907 Descriptio ...
- HNU 13108-Just Another Knapsack Problem (ac自动机上的dp)
题意: 给你一个母串,多个模式串及其价值,求用模式串拼接成母串(不重叠不遗漏),能获得的最大价值. 分析: ac自动机中,在字典树上查找时,用dp,dp[i]拼成母串以i为结尾的子串,获得的最大价值, ...
- 十字链表 Codeforces Round #367 E Working routine
// 十字链表 Codeforces Round #367 E Working routine // 题意:给你一个矩阵,q次询问,每次交换两个子矩阵,问最后的矩阵 // 思路:暴力肯定不行.我们可以 ...
- 时间,闰秒,及NTP
1.时间 格林尼治时间 GMT,以地球自转为准的时间,也叫世界时UT,但是由于自转速度会变化,所以后来不被作为标准. 世界协调时UTC,以原子钟为准,现在时间校准的标准就是原子钟. 2.闰秒 是指地球 ...
- Lucene Query Term Weighting
方法 public static Query TermWeighting(Query tquery,Map<String,Float>term2weight){ BooleanQuery ...
- Chapter 1 初探Caffe
首先下载windows下源码: Microsoft 官方:GitHub - Microsoft/caffe: Caffe on both Linux and Windows 官方源码使用Visual ...
- 关于 终端 ls 命令 不能区分文件和目录的问题
默认的,使用ls命令来显示目录内容的时候,“终端”对于目录.可执行文件等特殊类型的文件并没有使用颜色来显示,只有使用“ls -G”时,才能显示颜色,这可真是不方便.有没有方法可以默认显示颜色呢?方法当 ...
- Web Service学习之七:CXF拦截器
一.用途 CXF拦截器类似Struts2的拦截器,后者是拦截和处理请求,前者是对发送和接收的sope消息进行处理,一般用于WS请求响应中的权限验证.日志记录,Soap消息处理,消息的压缩处理等: 这个 ...