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 感谢