zoukankan      html  css  js  c++  java
  • 牛客算法周周练D题

    //这是一题无向图的题目。
    #include<bits/stdc++.h> using namespace std; const int N = 750005; int n,q; int h[N],ne[2*N],idx,e[2*N];//无向图记得开二倍int dp[N][3]; void add(int u,int v) { e[idx] = v; ne[idx] = h[u]; h[u] = idx++; } // 无向图的存储 void dfs(int u, int fa) { f[u] = fa; for(int i = h[u];i != -1;i = ne[i]) { int v = e[i]; if(v == fa) continue; dfs(v,u); } } //遍历所有节点的父亲节点 int main() { memset(h,-1,sizeof h); scanf("%d%d",&n,&q); for(int i = 1;i < n;i ++) { int a,b; scanf("%d%d",&a,&b); add(a,b),add(b,a);//无向图的存储 } dfs(1,0); while(q--) { int x; scanf("%d",&x); dp[x][1]++;dp[x][2]++; // 跟自身距离为2的点 dp[f[x]][0]++;dp[f[f[x]]][0]++; // 父亲节点和爷爷节点 dp[f[x]][1]++;// 与父亲节点距离为1的点      //注意这里不能写dp[x][0]++,因为这个会与父亲节点距离为1的点重复。 printf("%d ",dp[x][0]+dp[f[x]][1]+dp[f[f[x]]][2]); //输出当前这个点距离为2的点的所有被炸情况 } return 0; }

    题目来源:https://ac.nowcoder.com/acm/contest/5203/D

  • 相关阅读:
    CSU L: 就多了两分钟
    CSU 1112【机器人的指令】模拟
    P3388 【模板】割点(割顶)
    go 学习 2
    go 学习 1
    netconf协议
    lua 学习 5
    lua 学习 4
    lua 学习 3
    lua 学习 2
  • 原文地址:https://www.cnblogs.com/zyz010206/p/12708156.html
Copyright © 2011-2022 走看看