이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
void construct_network(int H, int W, int K);
int add_and(std::vector<int> Ns);
int add_or(std::vector<int> Ns);
int add_xor(std::vector<int> Ns);
int add_not(int N);
int tiles[505][505];
void plotar_tiles(int H,int W){
for(int i=0;i!=H;++i){
for(int j=0;j!=W;++j){
tiles[i][j]=(i*W)+j;
}
}
}
void construct_network(int H, int W, int K) {
plotar_tiles(H,W);
///Min(H,W) == 1
if(std::min(H,W)==1){
if(H==1){
int count=0;
for(int i=0;i!=W;++i){
int esperado = i+K;
if(esperado>=W)break;
std::vector<int> v;
v.push_back(tiles[0][i]);
v.push_back(tiles[0][esperado]);
add_and(v);
++count;
}
std::vector<int> orzao;
for(int i=0;i!=count;++i)orzao.push_back(H*W+i);
add_or(orzao);
}else {
assert(W==1);
int count=0;
for(int i=0;i!=H;++i){
int esperado = i+K;
if(esperado>=H)break;
std::vector<int> v;
v.push_back(tiles[i][0]);
v.push_back(tiles[esperado][0]);
add_and(v);
++count;
}
std::vector<int> orzao;
for(int i=0;i!=count;++i)orzao.push_back(H*W+i);
add_or(orzao);
}
}else assert(0);
}
# | 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... |