# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
100404 | 1Khan | Land of the Rainbow Gold (APIO17_rainbow) | C++14 | 0 ms | 0 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.
// In the name of GOD
#include "rainbow.h"
#include <bits/stdc++.h>
#include <ext/rope>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace std;
using namespace __gnu_cxx;
using namespace __gnu_pbds;
#define BeGood ios_base :: sync_with_stdio(0), cin.tie(0), cout.tie(0);
#define orset tree<int, null_type, less<int>, rb_tree_tag, tree_order_statistics_node_update>
#define nl '\n'
#define ff first
#define ss second
#define sz(x) (int)x.size()
#define all(x) x.begin(), x.end()
#define pb push_back
typedef long long ll;
typedef double db;
const int N = 1e4 + 5;
const int M = 1e9 + 7;
void init(int R, int C, int sr, int sc, int M, char *S){
BeGood
cin >> n >> k >> slen >> q;
int x, y;
cin >> x >> y;
cin >> s;
if(n <= 55 && k <= 55){
int a[111][111];
for(int i = 1; i <= n; ++i){
for(int j = 1; j <= k; ++j){
a[i][j] = 0;
}
}
for(int i = 1; i <= n; ++i){
for(int j = 1; j <= k; ++j){
a[i][j] = 0;
}
}
for(int i = 0; i < slen; ++i){
a[x][y] = 1;
if(s[i] == 'N'){
x--;
}
if(s[i] == 'W'){
y--;
}
if(s[i] == 'S'){
x++;
}
if(s[i] == 'E'){
y++;
}
}
a[x][y] = 1;
while(q){
int x1, y1, x2, y2;
colours(x1, y1, x2, y1);
q--;
}
} else{
int a[5][100111];
}
}
int colours(int ar, int ac, int br, int bc){
int ans = 0;
vector<int> t[55];
for(int i = 0; i < 54; ++i){
t[i].resize(k + 2, 0);
}
int ans = 0;
for(int i = x1; i <= x2; ++i){
for(int j = y1; j <= y2; ++j){
if(a[i][j] == 0){
if(t[i - 1][j] != 2 && t[i + 1][j] != 2 && t[i][j - 1] != 2 && t[i][j + 1] != 2){
ans++;
}
t[i][j] = 2;
}
}
}
return ans;
}