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 "plants.h"
using namespace std;
typedef long long ll;
vector<ll> lnk;
vector<int> a;
ll find(ll a) {
if (lnk[a] != a) lnk[a] = find(lnk[a]);
return lnk[a];
}
void unite(ll a, ll b) {
a = find(a); b = find(b);
lnk[b] = a;
}
bool same(ll a, ll b) {
return find(a) == find(b);
}
void init(int k, vector<int> r) {
ll n = r.size();
lnk = vector<ll>(n);
for (int i = 0; i < n; i++) lnk[i] = i;
for (int i = n-1; i >= 0; i--) {
int o = (i+1) % n;
if (r[i] == r[o]) unite(i, o);
}
a = vector<int>(n);
for (int i = 0; i < n; i++) a[i] = r[i];
}
int compare_plants(int x, int y) {
ll n = a.size();
ll dir = a[x];
for (int i = x; i != y; i++) {
if (dir != a[i]) break;
if (i == y-1) {
//return dir == 1 ? -1 : 1;
break;
}
}
dir = a[y];
for (int i = y; i != x; i = (i+1)%n) {
if (dir != a[i]) break;
if (i == (x-1+n)%n) {
return dir == 0 ? -1 : 1;
}
}
if (same(x, (y-1+n)%n)) {
return (a[x] ? -1 : 1);
}
if (same((x-1+n)%n, y)) {
return (!a[y] ? -1 : 1);
}
return 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... |