80分求助

P1434 [SHOI2002] 滑雪

xjy0820 @ 2022-06-13 20:31:50

代码如下

#include<bits/stdc++.h>
using namespace std;
int r,c,minn=100100,ans=0;
int h[105][105];
int d[4][2]={{-1,0},{1,0},{0,-1},{0,1}};
void dfs(int x,int y,int step){
    //cout<<x<<" "<<y<<" "<<step<<endl;
    if(h[x][y]==minn){
        ans=max(ans,step+1);
        return;
    }
    int xx,yy;
    for(int i=0;i<4;i++){
        xx=x+d[i][0];
        yy=y+d[i][1];
        if(xx>=1&&xx<=r&&yy>=1&&yy<=c&&h[x][y]>h[xx][yy]){
            dfs(xx,yy,step+1);
        } 
    }
}
int main()
{
    cin>>r>>c;
    for(int i=1;i<=r;i++){
        for(int j=1;j<=c;j++){
            cin>>h[i][j];
            if(minn>h[i][j]) minn=h[i][j];
        }
    }
    for(int i=1;i<=r;i++){
        for(int j=1;j<=c;j++){
            dfs(i,j,0);
        }
    }
    cout<<ans<<endl;
    return 0;
}

by aSunnyDay @ 2022-06-13 21:01:31

您可以用记忆化搜索。

即f[i][j]代表从第i行第j列开始滑最多能划多长路程

如果其他的依赖到了f[i][j]就可以直接返回而不是再算一遍


by aSunnyDay @ 2022-06-13 21:03:01

还有一次滑雪不一定到最低的那个点。


by xjy0820 @ 2022-06-14 20:17:21

谢谢谢谢


|