1. 程式人生 > >HDU2017新生賽 找方塊

HDU2017新生賽 找方塊

long long tdi memset its fin sync als push_back span

思路:

先n^3預處理出每個點能到達的(1010串)最上面的行下標。

然後再n^3暴力一下,對於每個點,往左走看能走到哪,邊走邊更新面積。

現在交不了題,代碼沒測過。

代碼:

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define pb push_back
#define mem(a,b) memset(a,b,sizeof(a))

const int N=105;
const int INF=0x3f3f3f3f;
int mp[N][N];
int suf[N][N];
int main() { ios::sync_with_stdio(false); cin.tie(0); int T; int n; cin>>T; while(T--) { cin>>n; mem(suf,INF); for(int i=0;i<n;i++) { for(int j=0;j<n;j++) cin>>mp[i][j],suf[i][j]=i; }
for(int i=0;i<n;i++) { for(int j=0;j<n;j++) { for(int k=i+1;k<n;k++) { if(mp[k][j]!=mp[k-1][j])suf[k][j]=min(suf[k][j],i); else break; } } }
int ans=0; for(int i=0;i<n;i++) { for(int j=0;j<n;j++) { int t=suf[i][j]; ans=max(ans,i-t+1); for(int k=j-1;k>=0;k--) { t=max(t,suf[i][k]); if(mp[i][k]!=mp[i][k+1]) { ans=max(ans,(j-k+1)*(i-t+1)); } else break; } } } cout<<ans<<endl; } return 0; }

HDU2017新生賽 找方塊