QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#432591 | #8686. Zoo Management | ORzyzRO | WA | 8ms | 46840kb | C++14 | 3.8kb | 2024-06-07 12:53:43 | 2024-06-07 12:53:44 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
#define int long long
#define pr pair<int, int>
#define pb push_back
#define mid (l + r) / 2
#define ls num << 1
#define rs num << 1 | 1
inline int read() {
int x = 0, m = 1;
char ch = getchar();
while (!isdigit(ch)) {
if (ch == '-') m = -1;
ch = getchar();
}
while (isdigit(ch)) {
x = x * 10 + ch - 48;
ch = getchar();
}
return x * m;
}
inline void write(int x) {
if (x < 0) {
putchar('-');
write(-x);
return;
}
if (x >= 10) write(x / 10);
putchar(x % 10 + '0');
}
const int N = 4e5 + 5;
int a[N], b[N], c[N << 1], ca[N], cb[N];
int dfn[N], low[N], vis[N], id[N], P[N];
stack<int> st;
vector<pr> v[N];
vector<int> val[N], Val[N];
int num = 0, cnt = 0;
void Tarjan(int ro, int fa) {
dfn[ro] = low[ro] = ++num;
st.push(ro);
for (auto u : v[ro]) {
int to = u.first, id = u.second;
if (id == fa) continue;
if (!dfn[to]) {
Tarjan(to, id);
low[ro] = min(low[ro], low[to]);
}
else low[ro] = min(low[ro], dfn[to]);
}
if (dfn[ro] == low[ro]) {
int now;
cnt++;
vector<int> dot, col1, col2;
dot.clear();
col1.clear();
col2.clear();
do {
now = st.top();
st.pop();
id[now] = cnt;
dot.pb(now);
} while (now != ro);
int res = 0;
for (auto u : dot) {
col1.pb(a[u]);
col2.pb(b[u]);
for (auto x : v[u]) {
if (id[x.first] == id[u]) res++;
}
}
sort(col1.begin(), col1.end());
sort(col2.begin(), col2.end());
for (int i = 0; i < col1.size(); i++) {
if (col1[i] != col2[i]) {
puts("impossible");
exit(0);
}
}
res /= 2;
if (res == dot.size()) {
for (auto u : dot) {
for (auto x : v[u]) {
if (id[x.first] == id[u]) {
val[a[u]].pb(a[x.first]);
Val[b[u]].pb(b[x.first]);
}
}
}
for (auto u : col1) {
sort(val[u].begin(), val[u].end());
sort(Val[u].begin(), Val[u].end());
if (val[u].size() != Val[u].size()) {
puts("impossible");
exit(0);
}
for (int i = 0; i < val[u].size(); i++) {
if (val[u][i] != Val[u][i]) {
puts("impossible");
exit(0);
}
}
val[u].clear();
Val[u].clear();
}
}
}
}
signed main() {
int n = read(), m = read(), k = 0;
for (int i = 1; i <= n; i++) {
a[i] = read();
b[i] = read();
c[++k] = a[i];
c[++k] = b[i];
}
sort(c + 1, c + k + 1);
k = unique(c + 1, c + k + 1) - c - 1;
if (k > n) {
puts("impossible");
return 0;
}
for (int i = 1; i <= n; i++) {
a[i] = lower_bound(c + 1, c + k + 1, a[i]) - c;
b[i] = lower_bound(c + 1, c + k + 1, b[i]) - c;
ca[a[i]]++;
cb[b[i]]++;
}
for (int i = 1; i <= k; i++) {
if (ca[i] != cb[i]) {
puts("impossible");
return 0;
}
}
for (int i = 1; i <= m; i++) {
int x = read(), y = read();
v[x].pb({y, i});
v[y].pb({x, i});
}
for (int i = 1; i <= n; i++) {
if (!dfn[i]) Tarjan(i, 0);
}
puts("possible");
}
详细
Test #1:
score: 100
Accepted
time: 3ms
memory: 46840kb
input:
6 7 1 1 2 2 3 3 1 2 2 3 3 1 1 2 2 3 1 3 3 4 4 5 5 6 4 6
output:
possible
result:
ok single line: 'possible'
Test #2:
score: -100
Wrong Answer
time: 8ms
memory: 46580kb
input:
5 6 10 10 20 20 30 30 40 50 50 40 1 2 2 3 1 3 3 4 3 5 4 5
output:
possible
result:
wrong answer 1st lines differ - expected: 'impossible', found: 'possible'