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 ...
随机推荐
- HDU 5365 Run
题意:给n个整点,问用其中若干个做顶点能够成多少个正三角形或正四边形或正五边形或正六边形. 解法:出题人说 地球人都知道整点是不能构成正五边形和正三边形和正六边形的,所以只需暴力枚举四个点判断是否是正 ...
- Kafka 设计与原理详解
一.Kafka简介 本文综合了我之前写的kafka相关文章,可作为一个全面了解学习kafka的培训学习资料. 转载请注明出处 : 本文链接 1.1 背景历史 当今社会各种应用系统诸如商业.社交.搜索. ...
- UI篇--布局问题
1.android:layout_marginRight 不起作用解决方法 今天想在RelativeLayout的左右分别放上一个按钮, 左边按钮用marginLeft="10dp" ...
- HDU-1438 钥匙计数之一
http://acm.hdu.edu.cn/showproblem.php?pid=1438 钥匙计数之一 Time Limit: 200 ...
- CSS中样式覆盖优先顺序
原文地址:http://www.3lian.com/edu/2014/09-25/168393.html 层叠优先级是: 浏览器缺省 < 外部样式表 < 内部样式表 < 内联样式 其 ...
- DateTime.IsLeapYear 方法判断是否是闰年,DaysInMonth判断一个月有几天,Addday取得前一天的日期GetYesterDay
一:DateTime.IsLeapYear 方法判断是否是闰年 二:代码 using System; using System.Collections.Generic; using System.Co ...
- cocos2d-x知识巩固-基础篇(1)
有段时间没有学习cocos2dx了,作为新人,自己觉得还是要稳扎稳打,一点点的去积累,梳理好每一个知识点,这样对自己的成长能够有一个更清晰的认识,以便做更好的提高. 从2013年8月开始接触cocos ...
- 02《老罗Android开发视频教程》第二集:android系统框架的介绍
- Ubuntu中、英文环境设置
改变ubuntu的中英文显示需要修改文件/etc/default/locale,具体设置过程为: 1.打开/etc/default/locale文件 #sudo vim /etc/default/lo ...
- L0、L1与L2范数、核范数(转)
L0.L1与L2范数.核范数 今天我们聊聊机器学习中出现的非常频繁的问题:过拟合与规则化.我们先简单的来理解下常用的L0.L1.L2和核范数规则化.最后聊下规则化项参数的选择问题.这里因为篇幅比较庞大 ...