poj(1088)——滑雪(经典递推型动归)

题意:

中文题,就是在所有的点中找一个点作为起点,然后叫你找出从起点开始的最长路径是多少。

这里高度必须严格递减。

思路:

一开始我碰到这题时,没有思路,是看题解写的。

但是今天我回头再去看时,发现自己能够独立写出来了,而且和上次的方法不一样。也许这就是进步吧!

其实就是一个递推型动归,如果理解了上一题,那么这题也好做了。

这是第一次写的:

#include
#include
#include
#include
using namespace std;
#define maxn 111
#define maxh 11111
int a[maxn][maxn],dp[maxn][maxn];
int getmax(int up,int down,int left,int right){
	if(up>=down&&up>=left&&up>=right) return up;
	if(down>=up&&down>=left&&down>=right) return down;
	if(left>=up&&left>=down&&left>=right) return left;
	if(right>=up&&right>=down&&right>=left) return right;
	return -1;
}
int DP(int x,int y){
	int up=-1,down=-1,left=-1,right=-1;
	if(dp[x][y]>=0) return dp[x][y];
	if(a[x-1][y]

这里dp[i][j]是保存从(i,j)点开始的最长路径。


第二次(个人感觉比较好懂的):

#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;
#define maxn 111
int r,c;
int a[maxn][maxn],dp[maxn][maxn];
int dx[4]={0,1,0,-1},dy[4]={1,0,-1,0};
int DP(int x,int y){
	if(dp[x][y]>=0) return dp[x][y];
	int ans=0,smax=0;
	for(int i=0;i<4;i++){
		int tx=x+dx[i];
		int ty=y+dy[i];
		if(tx<1||tx>r||ty<1||ty>c) continue;
		if(a[tx][ty]

//注意理解这里smax和ans的作用!

你可能感兴趣的:(基础dp)