이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define int long long
#define fi first
#define se second
using namespace std;
int32_t main()
{
ios_base::sync_with_stdio(false);
cin.tie(NULL);
int n, m, k;
cin >> n >> m >> k;
vector<vector<pair<int, int>>> v(n + 1);
for (int i = 0; i < n - 1; i++) {
int a, b;
cin >> a >> b;
v[a].push_back({b, i});
v[b].push_back({a, i});
}
int tim = 0;
vector<int> dep(n + 1, -1), tin(n + 1), tout(n + 1);
vector<vector<int>> p(n + 1, vector<int>(20));
function<void(int, int)> dfs = [&](int x, int pr) {
dep[x] = dep[pr] + 1;
tin[x] = ++tim;
p[x][0] = pr;
for (int j = 1; j < 20; j++) p[x][j] = p[p[x][j - 1]][j - 1];
for (auto [z, i] : v[x]) {
if (z == pr) continue;
dfs(z, x);
}
tout[x] = tim;
};
dfs(1, 1);
auto upper = [&](int x, int y) {
return tin[x] <= tin[y] && tout[y] <= tout[x];
};
auto lca = [&](int x, int y) {
if (upper(x, y)) return x;
if (upper(y, x)) return y;
for (int j = 19; j >= 0; j--) {
if (!upper(p[x][j], y)) {
x = p[x][j];
}
}
return p[x][0];
};
vector<int> dp(n + 1);
for (int i = 0; i < m; i++) {
int s;
cin >> s;
vector<int> ver;
for (int j = 0; j < s; j++) {
int x;
cin >> x;
ver.push_back(x);
}
sort(ver.begin(), ver.end(), [&](int x, int y) {
return tin[x] < tin[y];
});
for (int j = 0; j < s - 1; j++) {
int z = lca(ver[j], ver[j + 1]);
ver.push_back(z);
}
sort(ver.begin(), ver.end(), [&](int x, int y) {
return tin[x] < tin[y];
});
ver.erase(unique(ver.begin(), ver.end()), ver.end());
vector<int> st = {ver[0]};
for (int j = 1; j < (int)ver.size(); j++) {
int x = ver[j];
while ((int)st.size() >= 2 && !upper(st.back(), x)) {
dp[st.back()] += 1;
dp[st[(int)st.size() - 2]] -= 1;
st.pop_back();
}
st.push_back(x);
}
while ((int)st.size() >= 2) {
dp[st.back()] += 1;
dp[st[(int)st.size() - 2]] -= 1;
st.pop_back();
}
}
vector<int> ans;
function<void(int, int)> dfs2 = [&](int x, int p) {
for (auto [z, i] : v[x]) {
if (z == p) continue;
dfs2(z, x);
if (dp[z] >= k) ans.push_back(i);
dp[x] += dp[z];
}
};
dfs2(1, 1);
sort(ans.begin(), ans.end());
cout << (int)ans.size() << '\n';
for (auto x : ans) cout << x + 1 << " ";
cout << '\n';
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... |