递推型DP

将每个滑雪点都看作起点,从最低点开始逐个由四周递推出到达此点的最长路径的长度,由该点记下。

理论上,也可以将每一点都看作终点,由最高点开始计数,有兴趣可以试试。

//经典DP-由高向低海拔滑雪-求最长路
//Memory:372K Time:16 Ms
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std; #define MAX 105 int row, col, len;
int map[MAX][MAX]; //标准记录
int mov[][] = { { , },{ -, },{ , },{ , - } };
int d[MAX][MAX]; //dp[]
int ans; /*各点属性*/
struct Node {
int x, y; //坐标(x,y)
int value; //海拔
}node[MAX*MAX]; bool operator < (const Node a, const Node b)
{
return a.value < b.value;
} void DP()
{
ans = ;
memset(d, , sizeof(d));
for (int i = ; i < len; i++)
{
int x = node[i].x, y = node[i].y;
for (int j = ; j < ; j++)
{
int tx = x + mov[j][];
int ty = y + mov[j][];
if (tx >= && tx < row && ty >= && ty < col)
{
if (map[x][y] > map[tx][ty])
d[x][y] = max(d[x][y], d[tx][ty] + );
}
d[x][y] = max(, d[x][y]);
}
ans = max(ans, d[x][y]);
}
return;
} int main()
{
scanf("%d%d", &row, &col);
len = ;
for (int i = ; i < row; i++)
{
for (int j = ; j < col; j++)
{
scanf("%d", &map[i][j]);
node[len].x = i;
node[len].y = j;
node[len++].value = map[i][j];
}
}
sort(node, node + len); //将各点按照-升序-排列
DP();
printf("%d\n", ans);
return ;
}

记忆化搜索型DP

  不必排序,解法和思路也相对更加清晰

  

 //经典DP-由高向低海拔滑雪-求最长路
//Memory:252K Time:16 Ms
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std; #define max(x,y) ((x)>(y)?(x):(y))
#define MAX 105 int row, col;
int map[MAX][MAX]; //标准记录
int mov[][] = { { , },{ -, },{ , },{ , - } };
int d[MAX][MAX]; //distance
int ans; int DFS(int x, int y)
{
if (d[x][y]) return d[x][y]; for (int i = ; i < ; i++)
{
int tx = x + mov[i][];
int ty = y + mov[i][];
if (tx >= && tx < row && ty >= && ty < col)
if (map[tx][ty] < map[x][y]) //向下滑雪
d[x][y] = max(DFS(tx, ty) + , d[x][y]);
} ans = max(d[x][y], ans);
return d[x][y];
} int main()
{
scanf("%d%d", &row, &col); for (int i = ; i < row; i++)
for (int j = ; j < col; j++)
scanf("%d", &map[i][j]); memset(d, , sizeof(d));
for (int i = ; i < row; i++)
for (int j = ; j < col;j++)
DFS(i,j); printf("%d\n", ans + );
return ;
}

ACM/ICPC 之 简单DP-记忆化搜索与递推(POJ1088-滑雪)的更多相关文章

  1. 由DAG到背包问题——记忆化搜索和递推两种解法

    一.问题描述 物品无限的背包问题:有n种物品,每种均有无穷多个.第 i 种物品的体积为Vi,重量为Wi.选一些物品装到一个容量为 C 的背包中,求使得背包内物品总体积不超过C的前提下重量的最大值.1≤ ...

  2. ACM International Collegiate Programming Contest, Tishreen Collegiate Programming Contest (2017)- K. Poor Ramzi -dp+记忆化搜索

    ACM International Collegiate Programming Contest, Tishreen Collegiate Programming Contest (2017)- K. ...

  3. POJ 1088 DP=记忆化搜索

    话说DP=记忆化搜索这句话真不是虚的. 面对这道题目,题意很简单,但是DP的时候,方向分为四个,这个时候用递推就好难写了,你很难得到当前状态的前一个真实状态,这个时候记忆化搜索就派上用场啦! 通过对四 ...

  4. 【bzoj5123】[Lydsy12月赛]线段树的匹配 树形dp+记忆化搜索

    题目描述 求一棵 $[1,n]$ 的线段树的最大匹配数目与方案数. $n\le 10^{18}$ 题解 树形dp+记忆化搜索 设 $f[l][r]$ 表示根节点为 $[l,r]$ 的线段树,匹配选择根 ...

  5. 【BZOJ】1415 [Noi2005]聪聪和可可 期望DP+记忆化搜索

    [题意]给定无向图,聪聪和可可各自位于一点,可可每单位时间随机向周围走一步或停留,聪聪每单位时间追两步(先走),问追到可可的期望时间.n<=1000. [算法]期望DP+记忆化搜索 [题解]首先 ...

  6. [题解](树形dp/记忆化搜索)luogu_P1040_加分二叉树

    树形dp/记忆化搜索 首先可以看出树形dp,因为第一个问题并不需要知道子树的样子, 然而第二个输出前序遍历,必须知道每个子树的根节点,需要在树形dp过程中记录,递归输出 那么如何求最大加分树——根据中 ...

  7. poj1664 dp记忆化搜索

    http://poj.org/problem?id=1664 Description 把M个相同的苹果放在N个相同的盘子里,同意有的盘子空着不放,问共同拥有多少种不同的分法?(用K表示)5.1.1和1 ...

  8. 状压DP+记忆化搜索 UVA 1252 Twenty Questions

    题目传送门 /* 题意:给出一系列的01字符串,问最少要问几个问题(列)能把它们区分出来 状态DP+记忆化搜索:dp[s1][s2]表示问题集合为s1.答案对错集合为s2时,还要问几次才能区分出来 若 ...

  9. ACM学习历程—POJ1088 滑雪(dp && 记忆化搜索)

    Description Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你.Michael想知道 ...

随机推荐

  1. fedora23忘记root密码怎么办??

    fedora23使用的是uefi, 不是 传统的grub 所以在编辑grub的时候, 跟以前的版本略有不同 最最重要的是: 在编辑启动条目的时候, 那个 linuxefi ... vmlinuz... ...

  2. thinkphp笔记16-20集

    16.ThinkPHP3.1.3使用视频教程--独立分组配置项与目录部署详解_高清 17.ThinkPHP3.1.3使用视频教程--RBAC详解(一)思路分析_高清 18.ThinkPHP3.1.3使 ...

  3. EDW on Hadoop(Hadoop上的数据仓库)技术选型和实践思考

    在这篇文章中, 将讨论EDW on Hadoop 有哪些备选方案, 以及我个人的倾向性, 最后是建构方法.  欢迎转载, 但必须注明原贴(刘忠武,  http://www.cnblogs.com/ha ...

  4. 【CISP笔记】操作系统安全

    账号安全设置 默认管理账号Administrator更名,设置密码(字母.数字.大小写字母.特殊字符,长度在8位以上). 本地安全策略 打开方式 win+R 输入ecpol.msc 账号锁定策略 用户 ...

  5. 一道Twitter面试题

    在微博上看到的这个问题,忍住没看答案自己解决了.建议没看过的同学也自己先尝试下. “看下面这个图片” 在这个图片里我们有不同高度的墙.这个图片由一个整数数组所代表,数组中每个数是墙的高度.上边的图可以 ...

  6. nginx专题

    1.Nginx和php性能优化相关 专家向磊http://slaytanic.blog.51cto.com/2057708/1173021 2.Puppet利用Nginx多端口实现负载均衡http:/ ...

  7. mybatis批量插入数据到oracle

    mybatis 批量插入数据到oracle报 ”java.sql.SQLException: ORA-00933: SQL 命令未正确结束“  错误解决方法 oracle批量插入使用 insert a ...

  8. 如何解决Mac里面解压后文件名乱码问题

    如果你把Mac当成你的主要工作机器,而你的同事用的都是Windows,有时候交换文档就是一件很痛苦的事,比如今天要说到的问题:当同事传给你一个zip文件,结果你拿过来解压后发现里面有些文件的文件名如果 ...

  9. Mysql InnoDB行锁实现方式

    Mysql InnoDB行锁实现方式 InnoDB行锁是通过给索引上的索引项加锁来实现的,这一点MySQL与Oracle不同,后者是通过在数据块中对相应数据行加锁来实现的.InnoDB这种行锁实现特点 ...

  10. Bootstrap编码规范

    黄金定律 永远遵循同一套编码规范 -- 可以是这里列出的,也可以是你自己总结的.如果你发现本规范中有任何错误,敬请指正.通过 open an issue on GitHub为本规范添加或贡献内容. 不 ...