Submission #303037

# Submission time Handle Problem Language Result Execution time Memory
303037 2020-09-19T19:18:22 Z iliccmarko Quality Of Living (IOI10_quality) C++14
Compilation error
0 ms 0 KB
#include <bits/stdc++.h>
#include<quality.h>
using namespace std;
#define ll long long
#define endl "\n"

using namespace std;

int rectange(int r, int c, int h, int w, int **q)
{
    int l = 1;
    int R = r*c;
    int ans;
    while(l<=R)
    {
        int mid = (l+R)/2;
        int mat[r][c];
        for(int i = 0;i<r;i++)
        {
            for(int j = 0;j<c;j++)
            {
                if(q[i][j]<mid)
                    mat[i][j] = -1;
                else if(q[i][j]==mid)
                    mat[i][j] = 0;
                else
                    mat[i][j] = 1;
            }
        }
        int prefix[r][c];
        for(int i = 0;i<r;i++)
        {
            for(int j = 0;j<c;j++)
            {
                if(j==0)
                {
                    prefix[i][j] = mat[i][j];
                }
                else
                {
                    prefix[i][j] = prefix[i][j-1] + mat[i][j];
                }
            }
        }
        int b, s, e;
        b = s = e = 0;
        int sum = 0;
        for(int i = w-1;i<c;i++)
        {
            for(int j = 0;j<h;j++)
            {
                if(i==w-1)
                {
                    sum+=prefix[j][w-1];
                }
                else
                {
                    sum+=prefix[j][i] - prefix[j][i-w];
                }
            }
            for(int j = w;j<=h;j++)
            {
                if(sum<0)
                {
                    s++;
                    break;
                }
                else if(sum==0)
                {
                    e++;
                }
                if(j==h) break;
                if(i==w-1)
                {
                    sum-=prefix[j-h][w-1];
                    sum+=prefix[j][w-1];
                }
                else
                {
                    sum-=prefix[j-h][i-w];
                    sum+=prefix[j][i-w];
                }
            }
            if(s!=0) break;
        }
        if(s)
        {
            R = mid - 1;
        }
        else if(e)
        {
            ans = mid;
            l = mid + 1;
        }
        else
        {
            l = mid + 1;
        }
    }
    return ans;
}

Compilation message

quality.cpp: In function 'int rectange(int, int, int, int, int**)':
quality.cpp:45:13: warning: variable 'b' set but not used [-Wunused-but-set-variable]
   45 |         int b, s, e;
      |             ^
quality.cpp:100:12: warning: 'ans' may be used uninitialized in this function [-Wmaybe-uninitialized]
  100 |     return ans;
      |            ^~~
/tmp/ccEtvY6h.o: In function `main':
grader.cpp:(.text.startup+0xcd): undefined reference to `rectangle(int, int, int, int, int (*) [3001])'
collect2: error: ld returned 1 exit status