O(n3) 它爆过去了!!!
#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;
}