HDU2017新生賽 找方塊
阿新 • • 發佈:2017-11-25
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新生賽 找方塊