【♂Not The Triumph♂O(∩_∩)O哈哈~But The Struggle♂】

竞赛决不是捷径,它只是另一种艰辛的生活方式。得到与失去,只有时间会去评判;成功与失败,只有历史能去仲裁。我不会永远成功,正如我不会永远失败一样

  C++博客 :: 首页 :: 联系 ::  :: 管理
  6 Posts :: 239 Stories :: 25 Comments :: 0 Trackbacks

常用链接

留言簿(7)

我参与的团队

搜索

  •  

积分与排名

  • 积分 - 108444
  • 排名 - 229

最新评论

阅读排行榜

评论排行榜

有个公司要举行一场晚会。
为了能玩得开心,公司领导决定:如果邀请了某个人,那么一定不会邀请他的上司
(上司的上司,上司的上司的上司……都可以邀请)。

每个参加晚会的人都能为晚会增添一些气氛,求一个邀请方案,使气氛值的和最大。

input:
第1行一个整数N(1<=N<=6000)表示公司的人数。
接下来N行每行一个整数。第i行的数表示第i个人的气氛值x(-128<=x<=127)。
接下来每行两个整数L,K。表示第K个人是第L个人的上司。
输入以0 0结束。

output:
一个数,最大的气氛值和。

input:

7
1
1
1
1
1
1
1
1 3
2 3
6 4
7 4
4 5
3 5
0 0


output:
5

分析:

f[i,1]表示邀请i的最大值          f[i,2]表示不邀请i的最大值

f[i,1]=sigma(f[i.sons,2])              f[i,2]=sigma(max{f[i.sons,1],f[i.sons,2]})

这个又是树型动态规划的一种分类,每个结点都有二种状态既选与不选。

【参考程序】:
#include<iostream>
using namespace std;
int f[6001][2],father[6001];
bool v[6001];
int n;
int find_max(int a,int b)
{
    
if (a>b) return a;
    
else return b;
}
void dfs(int k)
{
    v[k]
=false;
    
for (int i=1;i<=n;i++)
        
if (v[i] && father[i]==k)
        {
            dfs(i);
            f[k][
0]+=f[i][1];
            f[k][
1]+=find_max(f[i][0],f[i][1]);
        }
}
int main()
{
    scanf(
"%d",&n);
    
for (int i=1;i<=n;i++) scanf("%d",&f[i][0]);
    
int l,k,root;
    root
=0;bool bk=true;
    
while (scanf("%d%d",&l,&k),l+k>0)
    {
        father[l]
=k;
        
if (root==|| bk==true)
        {
            root
=k;bk=false;
        }
    }
    memset(v,
true,sizeof(v));
    dfs(root);
    printf(
"%d\n",find_max(f[root][0],f[root][1]));
    
return 0;
}

【参考程序】:
#include<iostream>
using namespace std;
int f[2][6001],now[6001],pre[6001],child[6001];
int n;
int Max(int a,int b)
{
    
if (a>b) return a;
    
else return b;
}
void dfs(int k)
{
    
while (now[k])
    {
        dfs(child[now[k]]);
        f[
0][k]+=f[1][child[now[k]]];
        f[
1][k]+=Max(f[0][child[now[k]]],f[1][child[now[k]]]);
        now[k]
=pre[now[k]];
    }
}
int main()
{
    scanf(
"%d",&n);
    
for (int i=1;i<=n;i++)
    {
        scanf(
"%d",&f[0][i]);
        pre[i]
=child[i]=now[i]=0;
    }
    
int root,k,l;
    root
=(n+1)*n/2;
    
for (int i=1;i<=n-1;i++)
    {
        scanf(
"%d%d",&l,&k);
        child[i]
=l;pre[i]=now[k];
        now[k]
=i;root-=l;
    }
    dfs(root);
    printf(
"%d\n",Max(f[0][root],f[1][root]));
    
return 0;
}
posted on 2009-05-30 16:26 开拓者 阅读(363) 评论(0)  编辑 收藏 引用 所属分类: URAL 题解

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