zoukankan      html  css  js  c++  java
  • POJ 3107 Godfather (树重心)

    题目链接:http://poj.org/problem?id=3107

    题意:

            数重心,并按从小到大输出。

    思路:

            dfs

     1 #include <iostream>
     2 #include <cstdio>
     3 #include <cstring>
     4 #include <vector>
     5 using namespace std;
     6 const int N = 5e4 + 5;
     7 struct Edge {
     8     int next, to;
     9 }edge[N << 1];
    10 vector <int> G[N];
    11 int dp[N], n, head[N], cnt;
    12 
    13 inline void add(int u, int v) {
    14     edge[cnt].next = head[u];
    15     edge[cnt].to = v;
    16     head[u] = cnt++;
    17 }
    18 
    19 int dfs(int u, int p) {
    20     dp[u] = 0;
    21     int sum = 0;
    22     for(int i = head[u]; ~i; i = edge[i].next) {
    23         int v = edge[i].to;
    24         if(v == p)
    25             continue;
    26         int temp = dfs(v, u);
    27         dp[u] = max(dp[u], temp);
    28         sum += temp;
    29     }
    30     dp[u] = max(dp[u], n - sum - 1);
    31     return sum + 1;
    32 }
    33 
    34 int main()
    35 {
    36     while(~scanf("%d", &n)) {
    37         for(int i = 1; i <= n; ++i) {
    38             head[i] = -1;
    39         }
    40         cnt = 0;
    41         for(int i = 1; i < n; ++i) {
    42             int u, v;
    43             scanf("%d %d", &u, &v);
    44             add(u, v);
    45             add(v, u);
    46         }
    47         dfs(1, -1);
    48         int Max = n;
    49         vector <int> ans;
    50         for(int i = 1; i <= n; ++i) {
    51             Max = min(Max, dp[i]);
    52         }
    53         for(int i = 1; i <= n; ++i) {
    54             if(Max == dp[i]) {
    55                 ans.push_back(i);
    56             }
    57         }
    58         for(int i = 0; i < ans.size(); ++i) {
    59             if(i == ans.size() - 1) {
    60                 printf("%d
    ", ans[i]);
    61             } else {
    62                 printf("%d ", ans[i]);
    63             }
    64         }
    65     }
    66     return 0;
    67 }
  • 相关阅读:
    android笔记:ListView及ArrayAdapter
    android示例:一个简单的登陆程序
    Android笔记:RelativeLayout
    Android笔记:ContextMenu
    java swing示例
    java多线程与并发笔记
    java常用代码
    java学习笔记整理
    Android笔记:intent
    Android笔记:Button
  • 原文地址:https://www.cnblogs.com/Recoder/p/5949149.html
Copyright © 2011-2022 走看看