zoukankan      html  css  js  c++  java
  • 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
    ", 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;
    }
    


  • 相关阅读:
    Linux进程监控命令
    自学Java第九天
    自学Java第十天
    自学Java第八天
    自学Java第七天
    自学Java第六天
    Java第五天
    Java练习第四天
    自学Java第三天
    自学Java第二天
  • 原文地址:https://www.cnblogs.com/vactor/p/4100010.html
Copyright © 2011-2022 走看看