• <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>

            C小加

            厚德 博學 求真 至善 The bright moon and breeze
            posts - 145, comments - 195, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            Ural 1039. Anniversary Party 解題報告

            Posted on 2011-12-04 11:08 C小加 閱讀(1558) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告
            TreeDP。狀態轉移方程式f[i][0]+=max(f[j][0],f[j][1]);f[i][1]+=f[j][0];j是i的直屬下屬,0表示這個人不參加舞會,1表示參加。
            #include<iostream>
            #include<cstdio>
            #include<cstring>
            using namespace std;
            const int MAXN=6003;
            int a[MAXN];
            int father[MAXN];
            int f[MAXN][2];
            int n;

            void TreeDP(int i)
            {
                f[i][1]=a[i];
                for(int j=1;j<=n;j++)
                {
                    if(father[j]==i)
                    {
                        TreeDP(j);
                        f[i][0]+=max(f[j][0],f[j][1]);
                        f[i][1]+=f[j][0];
                    }
                }
            }

            int main()
            {

                scanf("%d",&n);
                for(int i=1;i<=n;i++)
                {
                    scanf("%d",a+i);
                }
                int x,s;
                memset(father,0,sizeof(father));
                memset(f,0,sizeof(f));
                while(scanf("%d %d",&x,&s),x&&s)
                {
                    father[x]=s;
                }

                for(int i=1;i<=n;i++)
                {
                    if(father[i]==0)
                    {
                        TreeDP(i);
                        printf("%d\n",max(f[i][0],f[i][1]));
                        break;
                    }
                }


                return 0;
            }
            99久久99久久久精品齐齐| 亚洲国产香蕉人人爽成AV片久久 | 东方aⅴ免费观看久久av| 亚洲精品国产自在久久| 久久婷婷色综合一区二区| 亚洲国产精品一区二区久久hs| 久久99久久99精品免视看动漫| 国产精品成人99久久久久| 日本高清无卡码一区二区久久| 久久久久久伊人高潮影院| 国产欧美久久久精品| 亚洲色欲久久久久综合网| 久久超碰97人人做人人爱| 欧美一级久久久久久久大| 潮喷大喷水系列无码久久精品| 日本久久中文字幕| 国产精品免费福利久久| 久久婷婷人人澡人人爽人人爱| 爱做久久久久久| 777米奇久久最新地址| 亚洲精品WWW久久久久久| 999久久久无码国产精品| 久久中文字幕人妻丝袜| 国产精品一区二区久久精品无码| 久久精品国产99久久久古代| 中文字幕亚洲综合久久| 人妻精品久久无码专区精东影业| 久久精品国产72国产精福利| 国产午夜免费高清久久影院| 精品国产乱码久久久久软件| 91精品久久久久久无码| 久久国产乱子伦免费精品| 精品国产乱码久久久久软件 | 久久久久免费看成人影片| 久久久精品久久久久久| 国产一级持黄大片99久久| 久久久久人妻一区二区三区vr | 久久性精品| 久久亚洲中文字幕精品一区| 成人国内精品久久久久影院VR | 久久久一本精品99久久精品66|