pku2378 Tree Cutting 树上的DP

题意就是在树上找一个节点,删除后使得各个连通分支的点数不超过总点数的1/2
还是老方法,先对树DP一次,求得各个子树的节点数,然后再统计一次即可
贴代码

 1# include <iostream>
 2# include <cstdio>
 3# include <vector>
 4# include <algorithm>
 5int n;
 6using namespace std;
 7vector<int> g[10005];
 8int num[10005];
 9vector<int> ans;
10int dfs(int pos,int pre)
11{
12    for(vector<int>::iterator i=g[pos].begin();i!=g[pos].end();i++)
13      if((*i)==pre)
14      {
15          g[pos].erase(i);
16          break;
17      }

18    num[pos]=1;
19    for(int i=0;i<g[pos].size();i++)
20      num[pos]+=dfs(g[pos][i],pos);
21    return num[pos];
22}

23void cal(int pos)
24{
25   bool flag=true;
26      for(int i=0;i<g[pos].size();i++)
27      {
28         cal(g[pos][i]);
29         if(num[g[pos][i]]>(n>>1))
30           flag=false;
31      }

32   if(pos!=1&&num[1]-num[pos]>(n>>1)) flag=false;
33   if(flag) ans.push_back(pos);
34}

35int main()
36{
37   // freopen("input.txt","r",stdin);
38   // freopen("output.txt","w",stdout);
39    scanf("%d",&n);
40    for(int i=1;i<n;i++)
41    {
42       int u,v;
43       scanf("%d%d",&u,&v);
44       g[u].push_back(v);
45       g[v].push_back(u);
46    }

47    dfs(1,-1);
48    cal(1);
49    sort(ans.begin(),ans.end());
50    if(ans.empty())
51      printf("NONE\n");
52    else
53      for(int i=0;i<ans.size();i++)
54         printf("%d\n",ans[i]);
55   // system("pause");
56    return 0;
57}

58
59

posted on 2010-10-31 00:04 yzhw 阅读(123) 评论(0)  编辑 收藏 引用 所属分类: DP


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   博问   Chat2DB   管理


<2010年10月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

导航

统计

公告

统计系统

留言簿(1)

随笔分类(227)

文章分类(2)

OJ

最新随笔

搜索

积分与排名

最新评论

阅读排行榜