HDU-1428(记忆化搜索)
#include <iostream>
#include <cstring>
#include <queue>
using namespace std; struct node {
int x,y;
int d;
};
int n;
int map[][];
int dis[][];
__int64 dp[][];
int vis[][];
int dir[][] = {{,},{-,},{,},{,-}}; bool operator < (node a,node b) {
return a.d>b.d;
} void dfs()
{
priority_queue<node> que;
memset(vis,,sizeof(vis));
node tmp,next;
tmp.x = n;
tmp.y = n;
tmp.d = map[n][n];
que.push(tmp);
while(!que.empty())
{
tmp = que.top();
que.pop();
if(vis[tmp.x][tmp.y])
continue;
vis[tmp.x][tmp.y] = ;
dis[tmp.x][tmp.y] = tmp.d;
for(int i = ;i < ;i++) {
next.x = tmp.x+dir[i][];
next.y = tmp.y+dir[i][];
if(next.x<||next.x>n||next.y<||next.y>n||vis[next.x][next.y])
continue;
next.d = tmp.d + map[next.x][next.y];
que.push(next);
}
}
} __int64 solve(int x,int y)
{
if(dp[x][y] != -) return dp[x][y];
else {
node next;
dp[x][y] = ;
for(int i = ;i < ;i++) {
next.x = x+dir[i][];
next.y = y+dir[i][];
if(next.x<||next.x>n||next.y<||next.y>n)
continue;
next.d = dis[next.x][next.y];
if(next.d < dis[x][y])
dp[x][y]+=solve(next.x,next.y);
}
return dp[x][y];
}
} int main()
{
while(cin>>n)
{
memset(dp,-,sizeof(dp));
for(int i = ;i <= n;i++)
for(int j = ;j <= n;j++)
cin>>map[i][j];
dfs();
/*测试最小距离
cout<<endl<<"~~~"<<endl;
for(int i = 1;i <= n;i++)
for(int j = 1;j <= n;j++){
cout<<dis[i][j]<<' ';
if(j == n)
cout<<endl;
}
*/
dp[n][n] = ;
cout<<solve(,)<<endl;
}
return ;
}
HDU-1428(记忆化搜索)的更多相关文章
- hdu 4722(记忆化搜索)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4722 思路:简单的记忆化搜索,留意一下A==0时的情况就可以了. #include<iostre ...
- HDU 4597 记忆化搜索
² 博弈取牌—记忆化搜索 题目描述: 有两副带有数字的牌,(数字>0)两人轮流取,取中了某张牌,自己的分数就加上牌上的数字,但只能从两端取,每人都会用最优的策略使得自己的分数最高.问A先取,他能 ...
- hdu 1514 记忆化搜索
题意是给4堆(堆的高度小于等于40)有颜色(颜色的种类小于等于20)的物品,你有一个篮子最多能装5件物品,每次从这4堆物品里面任取一件物品放进篮子里,但是取每堆物品时,必须先取上面的物品,才能取下面的 ...
- hdu 1208 记忆化搜索
题目大意:只能按照格子上的数字*方向走,从左上走到右下Sample Input42331121312313110Sample Output3 直接记忆化搜索,注意是0的情况 #include<c ...
- hdu 4960 记忆化搜索 DP
Another OCD Patient Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Ot ...
- hdu 2089 记忆化搜索写法(数位dp)
/* 记忆化搜索,第二维判断是否是6 */ #include<stdio.h> #include<string.h> #define N 9 int dp[N][2],digi ...
- Hdu 4597记忆化搜索
好久没有做题了,水平已经完全在学弟之下了. 一个吉林邀请赛最水的题目.:( 其实这题一看到数据范围,只可以想到思路,直接爆搜,加个记忆化. 这题虽然A了,但是我还是没太想清楚一些边界情况,心虚着A了. ...
- HDU 1978 记忆化搜索(dfs+dp)
Y - How many ways Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u S ...
- hdu 1078(记忆化搜索)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1078 //dp[i][j]表示从点i,j处开始能获得的最多cheese #include <io ...
- hdu 1978 记忆化搜索
注意: dp[i][j] 表示(i,j)这个点有多少种方式 mark[i][j]表示这个点是否走过 假设有直接返回dp[i][j] dp的求法为全部梦走到点的dp的和 注意mark ...
随机推荐
- ICMP报文分析
一.概述: 1. ICMP同意主机或路由报告差错情况和提供有关异常情况.ICMP是因特网的标准协议,但ICMP不是高层协议,而是IP层的协议.通常ICMP报文被IP层或更高层协议(TCP或UDP) ...
- MFC中全局变量的定义及使用
用MFC制作的工程由很多文件构成,它不能象一般C++程序那样随意在类外定义全局变量,在这里要想定义能被工程内多个文件共享的全局变量和函数必须用一些特殊方法才行.实际上有多种方法可以实现,这里只介绍两种 ...
- boost 特点
功能强大 跨平台 开源 免费 构造精巧 C++扩展库
- Android android-common 常用功能和工具集合
本文内容 环境 android-common 项目结构 演示 android-common 参考资料 android-common 主要包括如下内容: 缓存,包括图片缓存.预取缓存.网络缓存. 公共 ...
- java设计模式---享元模式
享元模式 顾名思义:共享元对象.如果在一个系统中存在多个相同的对象,那么只需要共享一份对象的拷贝,而不必为每一次使用创建新的对象. 享元模式是为数不多的.只为提升系统性能而生的设计模式.它的主要作用就 ...
- Java多线程——多线程的基本概念和使用
一.进程和线程的基础知识 1.进程和线程的概念 进程:运行中的应用程序称为进程,拥有系统资源(cpu.内存) 线程:进程中的一段代码,一个进程中可以有多段代码.本身不拥有资源(共享所在进程的资源) 在 ...
- c#将Excel数据导入到数据库的实现代码(转载)
假如Excel中的数据如下: 数据库建表如下: 其中Id为自增字段: 代码如下: using System; using System.Collections.Generic ...
- ubuntu学习笔记--不断更新中
1.rpm软件包相关: rpm软件包安装命令: rpm -ivh linuxqq-v1.0.2-beta1.i386.rpm rpm软件默认安装路径查询: rpm -ql *.rpm ubuntu如何 ...
- congos 日期控件的简单使用
congos 添加html的标签,然后写上js的代码,这段代码的功能是得到前一天的日期. <input type="button" value="查询" ...
- 如何打开Windows Server 2003 内存寻址扩展
本文介绍了如何在系统内存大于4G的情况下,让windows2003 Advanced Server支持大内存的方法: 由于Windows2003 32bit是32位操作系统,当服务器配备内存高达4G时 ...