神奇的事情
  • 板块P1950 长方形
  • 楼主chzhh_111
  • 当前回复5
  • 已保存回复5
  • 发布时间2024/9/15 22:30
  • 上次更新2024/9/16 10:34:47
查看原帖
神奇的事情
1036707
chzhh_111楼主2024/9/15 22:30

O(n3)O(n^3) 它爆过去了!!!

#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=1001;
int n,m,up[N][N],ans;char a[N][N];
signed main()
{
	scanf("%lld%lld",&n,&m);
	for(int i=1;i<=n;i++)
	  for(int j=1;j<=m;j++) scanf("%lld",&a[i][j]);
	for(int i=1;i<=n;i++)
	  for(int j=1;j<=m;j++)
	    if(a[i-1][j]==1) up[i][j]=up[i-1][j]+1;
	      else up[i][j]=a[i][j];
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++)
		{
			int mini=N;
			for(int k=j;k>=1&&a[i][k]==1;k--)
			{
				mini=min(mini,up[i][k]);
				ans+=mini;
			}
		}
	printf("%lld",ans);
	return 0;
}
2024/9/15 22:30
加载中...