제출 #377341

#제출 시각아이디문제언어결과실행 시간메모리
377341autumn_eel식물 비교 (IOI20_plants)C++14
5 / 100
148 ms9364 KiB
#include "plants.h"

#include <bits/stdc++.h>
#define rep(i,n)for(int i=0;i<(int)(n);i++)
using namespace std;
typedef pair<int,int>P;

int n;
vector<P>xs;

void init(int k, std::vector<int> r){
	n=r.size();
	//k=2
	vector<int>v(2*r.size());
	rep(i,2*r.size()){
		v[i]=r[i%r.size()];
	}
	rep(i,v.size()){
		if(i==0||v[i-1]!=v[i]){
			xs.push_back(P(i,v[i]));
		}
	}
	xs.push_back(P(2*r.size(),0));
	return;
}

int compare_plants(int x, int y) {
	int id1=lower_bound(xs.begin(),xs.end(),P(x+1,0))-xs.begin()-1;
	int id2=lower_bound(xs.begin(),xs.end(),P(y+1,0))-xs.begin()-1;

	if(y<=xs[id1+1].first){
		if(xs[id1].second==0)return 1;
		else return -1;
	}
	if(x+n<=xs[id2+1].first){
		if(xs[id2].second==0)return -1;
		else return 1;
	}
	return 0;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...