• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            pku2378 Tree Cutting 樹上的DP

            題意就是在樹上找一個節(jié)點,刪除后使得各個連通分支的點數(shù)不超過總點數(shù)的1/2
            還是老方法,先對樹DP一次,求得各個子樹的節(jié)點數(shù),然后再統(tǒng)計一次即可
            貼代碼

             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 閱讀(130) 評論(0)  編輯 收藏 引用 所屬分類: DP

            <2010年11月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            導(dǎo)航

            統(tǒng)計

            公告

            統(tǒng)計系統(tǒng)

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            老色鬼久久亚洲AV综合| 久久93精品国产91久久综合| 婷婷伊人久久大香线蕉AV | 日本精品久久久久中文字幕8| 97久久精品人人做人人爽| 一本久道久久综合狠狠躁AV| 久久久久久无码Av成人影院| 久久久久亚洲精品无码网址| 精品伊人久久大线蕉色首页| 99久久人人爽亚洲精品美女| 天天爽天天狠久久久综合麻豆| 久久WWW免费人成—看片| 国产午夜免费高清久久影院| 久久综合色老色| 久久99精品久久久久久齐齐| 欧美大香线蕉线伊人久久| 久久久精品日本一区二区三区 | 国产精品女同一区二区久久| 久久亚洲私人国产精品vA| 伊人久久大香线蕉综合5g| 99久久亚洲综合精品网站| 国产麻豆精品久久一二三| 精品久久久无码人妻中文字幕| 久久久无码精品亚洲日韩软件| 丁香五月网久久综合| 无码日韩人妻精品久久蜜桃| 亚洲精品视频久久久| 久久久精品日本一区二区三区| 色综合色天天久久婷婷基地| 国产精品久久久久久福利漫画 | 亚洲美日韩Av中文字幕无码久久久妻妇| 国产欧美久久一区二区| 99国产欧美精品久久久蜜芽| 午夜欧美精品久久久久久久| 五月丁香综合激情六月久久| 久久久国产打桩机| 久久精品国产99国产精品导航| 人人妻久久人人澡人人爽人人精品 | 久久无码国产| 久久久精品国产| 亚洲AV无码久久精品成人 |