hdu_4707

算是水題一道吧,我也沒有建樹,看別人又用vector,又用bfs,dfs的,對vector不熟,所以就模擬了一下
#include<iostream>
#include<string.h>
#include<cstdio>
using namespace std;
int a[100005];
int main()
{
    int t;cin>>t;
    while(t--)
    {
        int n,k,p,q;
        cin>>n>>k;
        a[0]=0;
        memset(a,0,sizeof(a));
        for(int i=0;i<n-1;i++)
            {
                scanf("%d%d",&p,&q);
                a[q]=a[p]+1;
            }
            p=0;
            for(int i=0;i<n;i++)
                if(a[i]>k)
                 p++;
                 cout<<p<<endl;
    }
    return 0;
}

附上別人的代碼

#include <cstdio>
#include <cstring>

using namespace std;

const int maxn = 100000 + 10;

int D, head[maxn], nxt[maxn<<1], v[maxn<<1], ecnt, d[maxn], ret;

void init(){
    memset(head, -1, sizeof(head));
    ecnt = 0;
    ret = 0;
}

void addEdge(int uu, int vv){
    v[ecnt] = vv;
    nxt[ecnt] = head[uu];
    head[uu] = ecnt;
    ecnt++;
}

void dfs(int x, int fa){
    if(d[x] > D) ret++;
    for(int e = head[x]; e != -1; e = nxt[e]) if(v[e] != fa){
        d[v[e]] = d[x] + 1;
        dfs(v[e], x);
    }
}

void solve(){
    d[0] = 0;
    dfs(0, -1);
    printf("%d\n", ret);
}

int main()
{
    int T, N, uu, vv;
    scanf("%d", &T);
    while(T--){
        init();
        scanf("%d%d", &N, &D);
        for(int i = 0; i < N-1; i++){
            scanf("%d%d", &uu, &vv);
            addEdge(uu, vv);
            addEdge(vv, uu);
        }
        solve();
    }
    return 0;
}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章