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>
using namespace std;
#define ll long long
#define ar array
const int mxN=2e5, INF=1e9;
int n, d[mxN], s[mxN], anc[mxN][18], ans[mxN+1], tin[mxN], tout[mxN];
vector<int> adj[mxN], stk;
set<ar<int, 2>> active, highest;
void dfs(int u=0) {
s[u]=1;
tin[u]=stk.size();
stk.push_back(d[u]);
for (int i=1; i<18; ++i)
anc[u][i]=anc[anc[u][i-1]][i-1];
for (int v : adj[u])
if (v!=anc[u][0]) {
d[v]=d[u]+1, anc[v][0]=u;
dfs(v);
s[u]+=s[v];
stk.push_back(d[u]);
}
tout[u]=stk.size()-1;
}
bool ia(int u, int v) {
return tin[u]<=tin[v]&&tout[v]<=tout[u];
}
int lca(int u, int v) {
if (ia(u, v)||ia(v, u))
return ia(u, v)?u:v;
for (int i=17; ~i; --i)
if (!ia(anc[u][i], v))
u=anc[u][i];
return anc[u][0];
}
int dist(int u, int v) {
return d[u]+d[v]-2*d[lca(u, v)];
}
struct Node {
int ans, mn, mx, lhs, rhs;
} st[1<<20];
Node cmb(Node a, Node b) {
return {
max({a.ans, b.ans, a.rhs+b.mx, a.mx+b.lhs}),
min(a.mn, b.mn),
max(a.mx, b.mx),
max({a.lhs, b.lhs, -2*a.mn+b.mx}),
max({a.rhs, b.rhs, a.mx-2*b.mn})
};
}
void bld(int u=1, int l=0, int r=2*n-2) {
if (l==r) {
st[u].mn=stk[l];
st[u].mx=st[u].lhs=st[u].rhs=-INF;
return;
}
int mid=(l+r)/2;
bld(2*u, l, mid);
bld(2*u+1, mid+1, r);
st[u]=cmb(st[2*u], st[2*u+1]);
}
void upd(int i, bool on, int u=1, int l=0, int r=2*n-2) {
if (l==r) {
//cout << "activating " << i << " " << on << endl;
st[u].mx=on?stk[l]:-INF;
st[u].lhs=st[u].rhs=on?-stk[l]:-INF;
return;
}
int mid=(l+r)/2;
i<=mid?upd(i, on, 2*u, l, mid):upd(i, on, 2*u+1, mid+1, r);
st[u]=cmb(st[2*u], st[2*u+1]);
}
int main() {
ios::sync_with_stdio(0);
cin.tie(0);
cin >> n;
for (int i=1; i<n; ++i) {
int u, v;
cin >> u >> v, --u, --v;
adj[u].push_back(v);
adj[v].push_back(u);
}
dfs();
assert(stk.size()==2*n-1);
bld();
vector<ar<int, 2>> subtrees, uptrees;
for (int i=1; i<n; ++i) {
subtrees.push_back({s[i], i});
uptrees.push_back({n-s[i], i});
}
sort(subtrees.begin(), subtrees.end());
sort(uptrees.begin(), uptrees.end());
fill(ans, ans+n+1, 1);
int best=1;
for (int i=n/2; i; --i) {
while(subtrees.size()&&subtrees.back()[0]>=i) {
int u=subtrees.back()[1];
subtrees.pop_back();
auto it=active.lower_bound({tin[u]});
if (it!=active.begin()) {
--it;
int v=(*it)[1];
if (ia(v, u)) {
upd(tin[v], 0);
active.erase(it);
}
}
upd(tin[u], 1);
active.insert({tin[u], u});
best=max(best, st[1].ans+1);
}
while(uptrees.size()&&uptrees.back()[0]>=i) {
int u=uptrees.back()[1];
uptrees.pop_back();
auto it=highest.lower_bound({tin[u]});
bool fine=1;
if (it!=highest.begin()) {
--it;
int v=(*it)[1];
fine=!ia(v, u);
}
if (fine) {
for (it=highest.lower_bound({tin[u]}); it!=highest.end()&&ia(u, (*it)[1]); it=highest.erase(it));
highest.insert({tin[u], u});
}
}
//cout << i << " " << best << endl;
for (ar<int, 2> x : active)
for (ar<int, 2> y : highest)
if (ia(y[1], x[1]))
best=max(best, d[x[1]]-d[y[1]]+2);
ans[2*i]=best;
}
for (int i=1; i<=n; ++i)
cout << ans[i] << "\n";
return 0;
}
Compilation message (stderr)
In file included from /usr/include/c++/10/cassert:44,
from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:33,
from meetings2.cpp:1:
meetings2.cpp: In function 'int main()':
meetings2.cpp:94:19: warning: comparison of integer expressions of different signedness: 'std::vector<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
94 | assert(stk.size()==2*n-1);
| ~~~~~~~~~~^~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |