80分求助

P1736 创意吃鱼法

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

过了!谢谢大佬!!!


|