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 "vision.h"
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int dist(ll a, ll b,int W){
return abs(a%W-b%W) + abs(a/W-b/W);
}
void construct_network(int H, int W, int K) {
vector<int> Ns;
ll it = 0;
vector<bool> vis(H*W);
for(int i = 0; i < W*H-1; i++){
vis[i] = 1;
for(int j = 0; j < W*H; j++){
if(dist(i, j, W) == K && !vis[j]){
Ns.push_back(j);
}
}
Ns.push_back(i);
add_xor(Ns);
Ns.pop_back();
add_xor(Ns);
Ns.clear();
it+=2;
}
//~ cerr << it << " ";
for(int i = H*W; i < H*W+it; i++) Ns.push_back(i);
if(!Ns.empty()) add_xor(Ns);
else add_or({0, 1});
//~ add_not(H*W+it);
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |