제출 #129905

#제출 시각아이디문제언어결과실행 시간메모리
129905AbelyanRailway (BOI17_railway)C++17
100 / 100
204 ms25712 KiB
#include <bits/stdc++.h>
using namespace std;
 
typedef long long ll;
typedef unsigned long long ull;
typedef long double ld;
 
#define FOR(i,a) for (int i=0;i<(a);++i)
#define FORD(i,a) for (int i=(a)-1;i>=0;i--)
#define FORT(i,a,b) for (int i=(a);i<=(b);++i)
#define FORTD(i,b,a) for (int i=(b);i>=(a);--i)
#define trav(i,v) for (auto i : v)
#define all(v) v.begin(),v.end()
#define ad push_back
#define fr first
#define sc second
#define mpr(a,b) make_pair(a,b)
#define pir pair<int,int>
#define all(v) v.begin(),v.end()
#define make_unique(v) v.erase(unique(all(v)),v.end())
#define fastio ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0);
#define srng mt19937 rng(chrono::steady_clock::now().time_since_epoch().count())
#define y1 EsiHancagorcRepa
 
const int N=1e5+10;
const ll MOD=1e9+7;
 
int n,m,k,lg,timer,tin[N],tout[N],anc[N][20],qan[N];;
vector<pir> g[N];
vector<int> ans;
 
void dfs(int v,int par=0){
    tin[v]=timer++;
    anc[v][0]=par;
    FORT(i,1,lg) anc[v][i]=anc[anc[v][i-1]][i-1];
 
    trav(tv,g[v]){
        int to=tv.fr;
        if (to==par){
            continue;
        }
        dfs(to,v);
    }
    tout[v]=timer++;
}
 
bool upper(int a,int b){
    return tin[a]<=tin[b] && tout[b]<=tout[a];
}
 
int lca(int a,int b){
    if (upper(a,b))return a;
    if (upper(b,a))return b;
    FORD(i,lg+1){
        if (!upper(anc[a][i],b)){
            a=anc[a][i];
        }
    }
    return anc[a][0];
}
 
int dfs2(int v,int par=0){
    int tiv=qan[v];
    //cout<<v<<" "<<tiv<<endl;
    trav(tv,g[v]){
        int to=tv.fr;
        if (to==par)continue;
        int cur=dfs2(to,v);
        if (cur>=k){
            ans.ad(tv.sc);
        }
        tiv+=cur;
    }
    return tiv;
}
set<int> st;
int get(int a){
    //cout<<tin[a]<<endl;
    if (st.lower_bound(tin[a])!=st.end() && *st.lower_bound(tin[a])==tin[a]) return a;
    FORD(i,lg+1){
        if (st.lower_bound(tin[anc[a][i]])==st.lower_bound(tout[anc[a][i]]+1)){
            a=anc[a][i];
            //cout<<"hey "<<a<<endl;
        }
    }
    return anc[a][0];
}
 
int main(){
    fastio;
    srng;
    cin>>n>>m>>k;
    FOR(i,n-1){
        int a,b;
        cin>>a>>b;
        a--;
        b--;
        g[a].ad({b,i+1});
        g[b].ad({a,i+1});
    }
    while((1<<lg)<=n)lg++;
    dfs(0);
    FOR(ttt,m){
        int s;
        cin>>s;
        vector<pir> vec;
        FOR(i,s){
            int a;
            cin>>a;
            a--;
            vec.ad({tin[a],a});
        }
        sort(all(vec));
        int lc=vec[0].sc;
        FORT(i,1,s-1){
            lc=lca(lc,vec[i].sc);
        }
        //cout<<lc<<endl;
        st.insert(tin[lc]);
        //cout<<"added "<<tin[lc]<<endl;
        FOR(i,s){
            qan[vec[i].sc]++;
            int verevin=get(vec[i].sc);
            //cout<<vec[i].sc<<" "<<verevin<<endl;
            qan[verevin]--;
            st.insert(tin[vec[i].sc]);
            //cout<<"added "<<tin[vec[i].sc]<<endl;
        }
        st.clear();
 
    }
    assert(dfs2(0)==0);
    cout<<ans.size()<<endl;
    sort(all(ans));
    FOR(i,ans.size()){
        cout<<ans[i]<<" ";
    }
    return 0;
}
 

컴파일 시 표준 에러 (stderr) 메시지

railway.cpp: In function 'int main()':
railway.cpp:8:32: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
 #define FOR(i,a) for (int i=0;i<(a);++i)
                                ^
railway.cpp:135:5: note: in expansion of macro 'FOR'
     FOR(i,ans.size()){
     ^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...