Submission #1017320

#TimeUsernameProblemLanguageResultExecution timeMemory
1017320NintsiChkhaidzeQuality Of Living (IOI10_quality)C++17
100 / 100
2479 ms212008 KiB
#include "quality.h"
#include <bits/stdc++.h>
#define pb push_back
using namespace std;

int a[3001][3001],pr[3001][3001];

int rectangle(int R, int C, int H, int W, int Q[3001][3001]) {
	vector <int> values;
	for (int i=0;i<R;i++)
		for (int j=0;j<C;j++)
			values.pb(Q[i][j]);
			
	sort(values.begin(),values.end());
	int l = 0,r = (int)values.size() - 1,ans = -1;
	
//	for (int y: values) cout<<y<<" ";
//	cout<<endl;
//	l = r = 19;
	while (l <= r){
		int mid = (l + r) >> 1;
		int mdn = values[mid],X,Y;
		
		for (int i=0;i<R;i++){
			for (int j=0;j<C;j++){
				if (Q[i][j] > mdn) a[i][j] = +1;
				else if (Q[i][j] < mdn) a[i][j] = -1; 
				else a[i][j] = 0,X=i,Y=j;
//				cout<<a[i][j]<<" ";
			}
//			cout<<endl;
		}
		
		bool check = 0;
		for (int i =0; i <R; i++){
			for (int j=0;j<C;j++){
				pr[i][j] = pr[i-1][j] + pr[i][j - 1] - pr[i - 1][j - 1] + a[i][j];
 			}
		}
		
//		cout<<"! "<<X <<" "<<Y<<endl;
		for (int i = 0 ;i + H - 1 < R; i++){
			for (int j = 0; j + W - 1 < C; j++){
				//if (!(X >= i && X <= i + H - 1 && Y >= j && Y <= j + W - 1)) continue;
				int sum = pr[i+H-1][j+W-1] - pr[i+H-1][j-1] - pr[i-1][j+W-1] + pr[i-1][j-1];
				if (sum<=0) {
//					cout<<"&&& "<<i<<" "<<j<<endl;
				check=1;break;}
			}
		}
		
		if (check){
			ans = mdn;
			r = mid - 1;
		}else{
			l = mid + 1;
		}
	}
	return ans;
}

Compilation message (stderr)

quality.cpp: In function 'int rectangle(int, int, int, int, int (*)[3001])':
quality.cpp:22:25: warning: variable 'X' set but not used [-Wunused-but-set-variable]
   22 |   int mdn = values[mid],X,Y;
      |                         ^
quality.cpp:22:27: warning: variable 'Y' set but not used [-Wunused-but-set-variable]
   22 |   int mdn = values[mid],X,Y;
      |                           ^
#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...