#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 = r;
}
int compare_plants(int x, int y) {
ll n = a.size();
if (same((x-1+n)%n, y)) {
x += n;
swap(x, y);
}
if (!same(x, (y-1)%n)) return 0;
return a[x] ? -1 : 1;
}
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
1 ms |
344 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
0 ms |
348 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
0 ms |
348 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
1 ms |
344 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
1 ms |
348 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
1 ms |
348 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
1 ms |
344 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |