114514_10086 @ 2023-11-21 22:23:54
程序如下
#include<bits/stdc++.h>
using namespace std;
int n,m,ans=-0x7fffffff;
int dp[2510][2510][2];
//dp[i][j][0]表示第i行第j列往右下角之最多的条数
//dp[i][j][1]表示第i行第j列往左下角之最多的条数
bool g[2510][2510];
bool check(int x,int y,int k)
{
if(k==0)
{
for(int i=1;i<=dp[x-1][y-1][0];i++)
if(g[x-i][y] || g[x][y-i]) return 0;
return 1;
}
else
{
for(int i=1;i<=dp[x-1][y+1][1];i++)
if(g[x-i][y] || g[x][y+i]) return 0;
return 1;
}
}
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
cin>>g[i][j];
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
{
if(g[i][j]) dp[i][j][0]=dp[i][j][1]=1;
if(g[i][j])
if(g[i-1][j-1])
if(check(i,j,0)) dp[i][j][0]+=dp[i-1][j-1][0];
if(g[i][j])
if(g[i-1][j+1])
if(check(i,j,1)) dp[i][j][1]+=dp[i-1][j+1][1];
ans=max(ans,max(dp[i][j][0],dp[i][j][1]));
}
cout<<ans;
return 0;
}
by __LePetitPrince__ @ 2023-11-21 22:27:48
@114514_10086 check 函数有问题,不一定要和上一个位置完全匹配,可能只有不能完全匹配但是也连续的一段
https://www.luogu.com.cn/record/133027411
by __LePetitPrince__ @ 2023-11-21 22:28:22
不保证正确(
肉眼看的
by 114514_10086 @ 2023-11-26 14:01:46
过了!谢谢大佬!!!