# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
82449 | Plurm | Highway design (CEOI12_highway) | C++11 | 3 ms | 1280 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>
#include "office.h"
using namespace std;
int main(){
int n = GetN();
int use = -1;
if(isOnLine(1,2,3)){
for(int i = 4; i+1 <= n; i += 2){
if(!isOnLine(1,i,i+1)){
int b1 = isOnLine(1,2,i);
int b2 = isOnLine(1,2,i+1);
if(!b1 && !b2){
Answer(1,2,i,i+1);
return 0;
}else if(!b1){
if(use == -1){
use = i;
}else{
Answer(1,2,use,i);
return 0;
}
}else if(!b2){
if(use == -1){
use = i+1;
}else{
Answer(1,2,use,i+1);
return 0;
}
}else{
// Contradiction.
throw 0;
}
}
}
Answer(1,2,use,n);
}else if(isOnLine(1,3,4)){
for(int i = 5; i+1 <= n; i += 2){
if(!isOnLine(1,i,i+1)){
int b1 = isOnLine(1,3,i);
int b2 = isOnLine(1,3,i+1);
if(!b1 && !b2){
Answer(1,3,i,i+1);
return 0;
}else if(!b1){
Answer(1,3,2,i);
return 0;
}else if(!b2){
Answer(1,3,2,i+1);
return 0;
}else{
// Contradiction.
throw 0;
}
}
}
Answer(1,3,2,n);
}else if(isOnLine(1,4,5)){
Answer(1,4,2,3);
}else if(isOnLine(2,3,4)){
for(int i = 5; i+1 <= n; i += 2){
if(!isOnLine(2,i,i+1)){
int b1 = isOnLine(2,3,i);
int b2 = isOnLine(2,3,i+1);
if(!b1 && !b2){
Answer(2,3,i,i+1);
return 0;
}else if(!b1){
Answer(2,3,1,i);
return 0;
}else if(!b2){
Answer(2,3,1,i+1);
return 0;
}else{
// Contradiction.
throw 0;
}
}
}
Answer(2,3,1,n);
}else{
if(isOnLine(2,3,5)){
Answer(1,4,2,3);
}else if(isOnLine(2,4,5)){
Answer(1,3,2,4);
}else if(isOnLine(3,4,5)){
Answer(1,2,3,4);
}else if(isOnLine(1,2,4)){
Answer(1,2,3,5);
}else if(isOnLine(1,2,5)){
Answer(1,2,3,4);
}else if(isOnLine(1,3,5)){
Answer(1,3,2,4);
}else{
throw 0;
}
}
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |