# | TimeUTC-0 | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
374185 | ivan_tudor | Furniture (JOI20_furniture) | C++14 | 2 ms | 896 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<bits/stdc++.h>
using namespace std;
const int N = 1005;
bool good[N][N];
int mat[N][N];
int lft[2*N];
int dx[] = {-1, 0, 1, 0};
int dy[] = {0, 1, 0, -1};
bool check(int i, int j){
for(int k = 0; k < 4; k++){
int ni1 = i + dx[k], ni2 = i + dx[(k + 1)%4];
int nj1 = j + dy[k], nj2 = j + dy[(k + 1)%4];
if(good[ni1][nj1] && good[ni2][nj2])
return true;
}
return false;
}
bool update(int i,int j){
if(lft[i + j] == 1)
return false;
good[i][j] = true;
lft[i + j]--;
for(int k = 0; k <4;k++){
int ni = i + dx[k];
int nj = j + dy[k];
if(good[ni][nj] == false && check(ni, nj)){
update(ni, nj);
}
}
return true;
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |