# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
602910 | misteg168 | Vision Program (IOI19_vision) | C++17 | 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.
#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++){
Ns.push_back(i);
vis[i] = 1;
for(int j = 0; j < W*H; j++){
if(dist(i, j, W) == K && !vis[j]){
Ns.push_back(j);
}
}
add_or(Ns);
add_xor(Ns);
add_nor(i);
Ns.clear();
it+=3;
}
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});
}