公式60pts?

P1719 最大加权矩形

Sam_Gamer @ 2023-08-10 22:27:31

#include<bits/stdc++.h>
#define maxn 125
using namespace std;
int main()
{
    long long a[maxn][maxn],b[maxn][maxn],n,ans=-2100000000;
    cin>>n;//套公式
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++)
        {
            cin>>a[i][j];   
        }
    }
    b[0][0]=a[0][0];
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++)
        {
            b[i][j]=b[i-1][j]+b[i][j-1]-b[i-1][j-1]+a[i][j];//处理上,左
        }
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++)
        {
            for(int k=1;k<=n;k++)
            {
                for(int l=1;l<=n;l++)
                {
                    if(ans<(b[k][l]-b[k][j-1]-b[i-1][l]+b[i-1][j-1])) ans=(b[k][l]-b[k][j-1]-b[i-1][l]+b[i-1][j-1]);
                }
            }
        }
      }
    cout<<ans;
    return 0;
}

用了二位前缀和和区间和,但是样例得17(样例15)


by Sam_Gamer @ 2023-08-10 22:28:12

刚开始以为是ans=0的问题,但貌似不是


by linxuanrui @ 2023-08-10 22:42:09

@Sam_Gamer 这里一共有 3 个错误。

  1. a,b 定义成全局数组,因为处理 b[1][1] 时用到了 b[1][0],而 b[1][0] 没有定义 。

  2. for(int k=1;k<=n;k++) 应为 for(int k=i;k<=n;k++),因为你不可能让开始的坐标大于结束的坐标吧。

  3. for(int l=1;l<=n;l++):同上。


by Sam_Gamer @ 2023-08-10 23:03:49

@linxuanrui 谢谢


|