結果
| 問題 |
No.2677 Minmax Independent Set
|
| コンテスト | |
| ユーザー |
👑 potato167
|
| 提出日時 | 2024-03-15 21:43:59 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 290 ms / 2,000 ms |
| コード長 | 4,398 bytes |
| コンパイル時間 | 2,336 ms |
| コンパイル使用メモリ | 215,060 KB |
| 最終ジャッジ日時 | 2025-02-20 04:49:37 |
|
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 61 |
ソースコード
#include <bits/stdc++.h>
#pragma GCC optimize("unroll-loops")
using namespace std;
using std::cout;
using std::cin;
using std::endl;
using ll=long long;
using ld=long double;
const ll ILL=2167167167167167167;
const int INF=2100000000;
const int mod=998244353;
#define rep(i,a,b) for (int i=(int)(a);i<(int)(b);i++)
#define all(p) p.begin(),p.end()
template<class T> using _pq = priority_queue<T, vector<T>, greater<T>>;
template<class T> ll LB(vector<T> &v,T a){return lower_bound(v.begin(),v.end(),a)-v.begin();}
template<class T> ll UB(vector<T> &v,T a){return upper_bound(v.begin(),v.end(),a)-v.begin();}
template<class T> bool chmin(T &a,T b){if(a>b){a=b;return 1;}else return 0;}
template<class T> bool chmax(T &a,T b){if(a<b){a=b;return 1;}else return 0;}
template<class T> void So(vector<T> &v) {sort(v.begin(),v.end());}
template<class T> void Sore(vector<T> &v) {sort(v.begin(),v.end(),[](T x,T y){return x>y;});}
void yneos(bool a,bool upp=0){if(a) cout<<(upp?"YES\n":"Yes\n"); else cout<<(upp?"NO\n":"No\n");}
template<class T> void vec_out(vector<T> &p,int ty=0){
if(ty==2){cout<<'{';for(int i=0;i<(int)p.size();i++){if(i){cout<<",";}cout<<'"'<<p[i]<<'"';}cout<<"}\n";}
else{if(ty==1){cout<<p.size()<<"\n";}for(int i=0;i<(int)(p.size());i++){if(i) cout<<" ";cout<<p[i];}cout<<"\n";}}
template<class T> T vec_min(vector<T> &a){assert(!a.empty());T ans=a[0];for(auto &x:a) chmin(ans,x);return ans;}
template<class T> T vec_max(vector<T> &a){assert(!a.empty());T ans=a[0];for(auto &x:a) chmax(ans,x);return ans;}
template<class T> T vec_sum(vector<T> &a){T ans=T(0);for(auto &x:a) ans+=x;return ans;}
int pop_count(long long a){int res=0;while(a){res+=(a&1),a>>=1;}return res;}
//https://trap.jp/post/1702/
template<class E, class V, E (*merge)(E, E), E (*e)(), E (*put_edge)(V, int), V (*put_vertex)(E, int)>
struct RerootingDP {
struct edge{
int from, to, idx, rev_idx;
};
RerootingDP (int _n = 0) : n(_n) { es.resize(n);}
void add_edge(int u, int v, int idx1, int idx2){
es[u].push_back({u,v,idx1,idx2});
es[v].push_back({v,u,idx2,idx1});
}
V build(int v = 0){
root = v;
vis.resize(n,0);
outs.resize(n);
return dfs(root);
}
vector<V> reroot(){
reverse_edge.resize(n);
reverse_edge[root] = e();
answers.resize(n);
bfs(root);
return answers;
}
private:
int n, root;
vector<vector<edge>> es;
vector<int> vis;
vector<vector<E>> outs;
vector<E> reverse_edge;
vector<V> answers;
V dfs(int v){
vis[v]++;
E val = e();
for (auto &p : es[v]){
if (vis[p.to] > 0 && p.to != es[v].back().to) swap(p,es[v].back());
if (vis[p.to] > 0) continue;
E nval = put_edge(dfs(p.to),p.idx);
outs[v].emplace_back(nval);
val = merge(val,nval);
}
return put_vertex(val,v);
}
void bfs(int v){
int siz = outs[v].size();
vector<E> lui(siz+1), rui(siz+1);
lui[0] = e(), rui[siz] = e();
for (int i = 0; i < siz; i++) lui[i+1] = merge(lui[i],outs[v][i]);
for (int i = siz-1; i >= 0; i--) rui[i] = merge(outs[v][i],rui[i+1]);
for (int i = 0; i < siz; i++){
reverse_edge[es[v][i].to] = put_edge(put_vertex(merge(merge(lui[i],rui[i+1]),reverse_edge[v]),v),es[v][i].rev_idx);
bfs(es[v][i].to);
}
answers[v] = put_vertex(merge(lui[siz],reverse_edge[v]), v);
}
};
struct reroot_F{
int black;
int white;
int large;
};
reroot_F merge(reroot_F a, reroot_F b){
return {a.black+b.black,a.white+b.white,a.large+b.large};
}
reroot_F e(){
return {0,0,0};
}
reroot_F put_edge(reroot_F v, int i){
return v;
}
reroot_F put_vertex(reroot_F e, int v){
e.black=e.white+1;
e.white=e.large;
e.large=max(e.black,e.white);
return e;
}
#define reroot_calc reroot_F,reroot_F,merge,e,put_edge,put_vertex
void solve();
// oddloop
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int t=1;
//cin>>t;
rep(i,0,t) solve();
}
void solve(){
int N;
cin>>N;
RerootingDP<reroot_calc> G(N);
rep(i,0,N-1){
int a,b;
cin>>a>>b;
G.add_edge(a-1,b-1,0,0);
}
G.build();
auto res=G.reroot();
int ans=INF;
rep(i,0,N) chmin(ans,res[i].black);
cout<<ans<<"\n";
}
potato167