Submission #831798

#TimeUsernameProblemLanguageResultExecution timeMemory
831798matthewhutamaQuality Of Living (IOI10_quality)C++14
100 / 100
2433 ms175488 KiB
#include "quality.h"
#include <bits/stdc++.h>
// #include <stdio.h>
// #include <stdlib.h>
// #include "quality.h"
using namespace std;
typedef long long ll;
int grid[3001][3001];
int pref[3005][3005];
// static int R,C,H,W,Q[3001][3001],i,j,ans;
int rectangle(int R, int C, int H, int W, int Q[3001][3001]) {
    int lo = 1, hi = R * C, simpan;
    while (lo <= hi){
        int mid = (lo + hi) / 2;
        memset(pref, 0, sizeof(pref));
        // cout<<mid<<endl;
        for (int i = 1; i <= R; i++){
            for (int j = 1; j <= C; j++){
                if (Q[i - 1][j - 1] == mid){
                    grid[i][j] = 0;
                }
                else if (Q[i - 1][j - 1] > mid){
                    grid[i][j] = 1;
                }
                else{
                    grid[i][j] = -1;
                }
                // cout << grid[i][j]<<" ";
            }
            // cout<<endl;
        }
        // cout<<"_____________________"<<endl;
        for (int i = 1; i <= R; i++){
            for (int j = 1; j <= C; j++){
                if (i == 1 && j == 1){
                    pref[i][j] = grid[i][j];
                    // cout<<pref[i][j]<<" ";
                    continue;
                }
                pref[i][j] = pref[i - 1][j] + pref[i][j - 1] - pref[i - 1][j - 1] + grid[i][j];
                // cout<<pref[i][j]<<" ";
            }
            // cout<<endl;
        }
        int x = 0;
        for (int i = 1; i <= R - H + 1; i++){
            if (x == 1) break;
            for (int j = 1; j <= C - W + 1; j++){
                int p = i + H - 1, q = j + W - 1;
                int u = pref[p][q] - pref[p][j - 1] - pref[i - 1][q] + pref[i - 1][j - 1];
                if (u <= 0){
                    x = 1;
                    break;
                }
            }
        }
        // cout<<"_______________________"<<endl;

        if (x == 0){
            lo = mid + 1;
        }
        else{
            hi = mid - 1;
            simpan = mid;
        }
    }
    return simpan;
}


// int main(){
//    scanf("%d%d%d%d",&R,&C,&H,&W);
//    for (i=0;i<R;i++) for (j=0;j<C;j++) scanf("%d",&Q[i][j]);
//    ans = rectangle(R,C,H,W,Q);
//    printf("%d\n",ans);
//    return 0;
// }

Compilation message (stderr)

quality.cpp: In function 'int rectangle(int, int, int, int, int (*)[3001])':
quality.cpp:67:12: warning: 'simpan' may be used uninitialized in this function [-Wmaybe-uninitialized]
   67 |     return simpan;
      |            ^~~~~~
#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...