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 ...
随机推荐
- MBR与GRUB简介
在坛子里找到一篇关于grub和mbr工作原理的文章,以前一直都是一头雾水,今天转这文章学习下..哈.. 能正常工作的grub应该包 括一下文件:stage1.stage2.*stage1_5.menu ...
- hdu 2825(ac自动机+状态压缩dp)
题意:容易理解... 分析:在做这道题之前我做了hdu 4057,都是同一种类型的题,因为题中给的模式串的个数最多只能为10个,所以我们就很容易想到用状态压缩来做,但是开始的时候我的代码超时了dp时我 ...
- C++11笔记
__func__宏 __func__返回当前的函数名,也可以返回class和struct名. /*返回函数名hello*/ const char* hello() { return __func__; ...
- 【剑指offer 面试题16】反转链表
思路: 用三个指针preNode.curNode.nextNode完成. #include <iostream> using namespace std; struct ListNode ...
- 精雕细琢 35 套精美的 PSD 图标素材
设计师总是有独特的创意和精雕细琢的精湛技术,让我们值得去欣赏和借鉴,如梦想天空所表达的:非常感谢那些很有才华的设计师分享它们的劳动成果,让更多的人可以使用他们的创意设计.今天,本文与大家分享35套精美 ...
- libpomelo的cocos2d-x客户端使用总结
这几天看了libpomelo的cocos2dx客户端这是个聊天室,由2个场景构成,登录场景LoginScene,聊天场景ChatScene. 一. LoginScene 客户端是以Login场景来启动 ...
- asp.net(class0625)
1 SiteMapPath 面包屑导航控件 要想使用这个控件,必须创建一个站点地图,也就是 web.sitemap web.sitemap是一个xml文件: 根节点必须是:<siteMap> ...
- Chapter3:字符串、向量和数组
C++11新特性:范围for(range for) for (declaration: expression) statement vector和数组都是对象的集合,而引用不是对象. vector对象 ...
- bzoj 2818 Gcd(欧拉函数 | 莫比乌斯反演)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2818 [题意] 问(x,y)为质数的有序点对的数目. [思路一] 定义f[i]表示i之 ...
- 现代程序设计 homework-05
本次作业要求设计服务器和客户端,由于之前对网络编程是一窍不通,上上节课听宗学长讲述Tcp的时候心里想这个东西还真是高大上啊一点儿都听不懂,但是上个周末看了看C#网络编程的博客和书之后,发现这个东西入门 ...