蒟蒻求助,只有60分

P1434 [SHOI2002] 滑雪

hyn281003 @ 2023-06-17 22:11:29

提交只得了60分,第6,8,9,10个点WA,看了两年半也没看出来。 代码如下:

#include<bits/stdc++.h>
using namespace std;
int a[105][105],r[105][105],n,m,ans;
int X[4]={0,0,1,-1};
int Y[4]={1,-1,0,0};
bool check(int x,int y,int nx,int ny){
    if(nx<=0||nx>n||ny<=0||ny>m)return false;
    if(a[x][y]<a[nx][ny])return false;
    return true;
}
int dfs(int x,int y){
    if(r[x][y]!=0)return r[x][y];
    r[x][y]=1;
    for(int i=0;i<4;i++){
        int nx=x+X[i],ny=y+Y[i];
        if(check(x,y,nx,ny)==true){
            dfs(nx,ny);
            r[x][y]=max(r[x][y],r[nx][ny]+1);
        }
    }
    return 0;
}
int main(){
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)scanf("%d",&a[i][j]);
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)dfs(i,j);
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)ans=max(ans,r[i][j]);
    printf("%d",ans);
    return 0;
}

by One_JuRuo @ 2023-06-17 22:26:02

@hyn281003 你dfs完了,应该returnr[x][y]吧,咋return 0呢?


by zhouzihe @ 2023-06-17 22:33:27

@hyn281003

#include<bits/stdc++.h>
using namespace std;
int r,c,a[200][200],f[200][200],maxn,xx[4]={-1,0,1,0},yy[4]={0,1,0,-1};
int dfs(int x,int y){
    if(f[x][y]!=0){
        return f[x][y];
    }
    int sum=0;
    for(int i=0;i<4;i++){
        int nx=x+xx[i];
        int ny=y+yy[i];
        if(a[nx][ny]<a[x][y]){
            sum=max(sum,dfs(nx,ny));
        }
    }
    return f[x][y]=sum+1;
}
int main(){
    memset(a,9999,sizeof(a));
    cin>>r>>c;
    for(int i=1;i<=r;i++){
        for(int j=1;j<=c;j++){
            cin>>a[i][j];
        }
    }
    for(int i=1;i<=r;i++){
        for(int j=1;j<=c;j++){
            if(f[i][j]==0){
                f[i][j]=dfs(i,j);
                maxn=max(maxn,f[i][j]);
            }
        }
    }
    cout<<maxn;
    return 0;
}

求关


by hyn281003 @ 2023-06-18 09:46:29

@zhouzihe 感谢


|