제출 #1130322

#제출 시각아이디문제언어결과실행 시간메모리
1130322brover29Bomb (IZhO17_bomb)C++20
17 / 100
1104 ms147768 KiB
#include <bits/stdc++.h> //qwerty47924692 #pragma GCC optimize("O3,unroll-loops") #pragma GCC target("avx2,bmi,bmi2,lzcnt,popcnt") using namespace std; using namespace std; using ll = long long; const ll N=2509; const string br="617283"; #define sz(a)(ll)a.size() #define f first #define s second ll n,m,a[N][N],used[N][N],pref[N][N]; ll calc(ll xa,ll ya,ll xb,ll yb){ return pref[xb][yb]-pref[xa-1][yb]-pref[xb][ya-1]+pref[xa-1][ya-1]; } bool can(ll x,ll y){ for(ll i=1;i<=n;i++){ for(ll j=1;j<=m;j++){ used[i][j]=0; } } for(ll i=1;i+x-1<=n;i++){ for(ll j=1;j+y-1<=m;j++){ if(a[i][j]==1&&calc(i,j,i+x-1,j+y-1)==x*y){ used[i][j]++; used[i][j+y]--; used[i+x][j]--; used[i+x][j+y]++; } } } for(ll i=1;i<=n;i++){ for(ll j=1;j<=m;j++){ used[i][j]+=used[i-1][j]+used[i][j-1]-used[i-1][j-1]; if(a[i][j]==1&&!used[i][j])return 0; } } return 1; } ll check(ll i){ ll l=0,r=m; while(l<r){ ll mid=(r+l+1)>>1; if(can(i,mid))l=mid; else r=mid-1; } return l*i ; } int main(){ ios_base::sync_with_stdio(0); cin.tie(0); cin>>n>>m; for(ll i=1;i<=n;i++){ for(ll j=1;j<=m;j++){ char c; cin>>c; a[i][j]=c-'0'; pref[i][j]=pref[i-1][j]+pref[i][j-1]-pref[i-1][j-1]+a[i][j]; } }ll ans=0; ll l=1,r=n; while(l<r){ ll mid=(r+l+1)>>1; if(check(mid))l=mid; else r=mid-1; } cout<<check(l); }
#Verdict Execution timeMemoryGrader output
Fetching results...