제출 #1110809

#제출 시각아이디문제언어결과실행 시간메모리
1110809epicci23Rectangles (IOI19_rect)C++17
37 / 100
5081 ms50972 KiB
#include "bits/stdc++.h"
//#define int long long
#define all(v) v.begin() , v.end()
#define sz(a) (int)a.size()
using namespace std;


long long count_rectangles(vector<vector<int>> ar){
  int n=sz(ar),m=sz(ar[0]);
  int64_t ans=0,a[n+5][m+5];
  for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) a[i][j]=ar[i-1][j-1];
  
  for(int i=2;i<n;i++){
    for(int j=2;j<m;j++){
      if(a[i][j]>=a[i-1][j] || a[i][j]>=a[i][j-1]) continue;
      
      for(int alt=i;alt<n;alt++){
       vector<int64_t> mr(n+5,0);

       for(int z=j;z<m;z++){
         int64_t cl=0;
         bool ok=1;
         for(int k=i;k<=alt;k++){
          mr[k]=max(mr[k],a[k][z]);
          cl=max(cl,a[k][z]);
          if(min(a[k][j-1],a[k][z+1])<=mr[k]) ok=0;
         }
         if(min(a[i-1][z],a[alt+1][z])<=cl) break;
         ans+=ok;
       }

      }


    }
  }

  return ans;
}



/*void _(){
  int n,m;
  cin >> n >> m;
  int ans=0,a[n+5][m+5];
  for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) cin >> a[i][j];
  
  for(int i=2;i<n;i++){
  	for(int j=2;j<m;j++){
  	  if(a[i][j]>=a[i-1][j] || a[i][j]>=a[i][j-1]) continue;
  	  
      for(int alt=i;alt<n;alt++){
       vector<int> mr(n+5,0);

       for(int z=j;z<m;z++){
         int cl=0;
         bool ok=1;
         for(int k=i;k<=alt;k++){
          mr[k]=max(mr[k],a[k][z]);
          cl=max(cl,a[k][z]);
          if(min(a[k][j-1],a[k][z+1])<=mr[k]) ok=0;
         }
         if(min(a[i-1][z],a[alt+1][z])<=cl) break;
         ans+=ok;
       }

      }


  	}
  }

  cout << ans << '\n';
}

int32_t main(){
  cin.tie(0); ios::sync_with_stdio(0);
  int tc=1;//cin >> tc;
  while(tc--) _();
  return 0;
}*/
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...