[Poi2014]FarmCraft 树状dp

本文介绍了一种基于树形结构的贪心算法实现方法,通过处理每个节点及其子树来解决特定问题。该算法首先定义了节点的相关属性,并利用递归深度优先搜索(DFS)策略来遍历整个树形结构,确保每次操作都尽可能地优化整体结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对于每个点,处理出走完其子树所需要的时间和其子树完全下载完软件的时间

易证,对于每个点的所有子节点,一定优先选择差值大的来给后面的时间

树规+贪心。

#include<cstdio>
#include<cstring>
#include<iostream>
#include<cmath>
#include<algorithm>
#include<queue>
#define N 500005
using namespace std;
int e=1,head[N],fa[N],n;
int a[N];
struct edge{
    int u,v,next;
}ed[2*N];
void add(int u,int v){
    ed[e].u=u; ed[e].v=v;
    ed[e].next=head[u];
    head[u]=e++;
}
struct data{
    int f,g,del;//f为出该子树用的时间,g为该子树装完软件的时间,del为差值;
    bool operator < (const data &a) const{
        return a.del>del;
    }
}da[N];
int q[N],top=0;
bool cmp(int x,int y)
{return da[x].del<da[y].del;}
void dfs(int x){
    int bottom=top;
    for(int i=head[x];i;i=ed[i].next){
        int v=ed[i].v;
        if(v==fa[x]) continue;
        fa[v]=x;
        dfs(v);
        q[++top]=v;
    }
    if(x!=1){
        da[x].g=1+a[x];
        da[x].f++;
    }
    sort(q+bottom+1,q+top+1,cmp);
    while(top>bottom){
        da[x].g=max(da[x].g,da[x].f+da[q[top]].g);
        da[x].f+=da[q[top]].f;
        top--;
    }
    if(x==1){da[x].g=max(da[x].g,da[x].f+a[x]);}
    if(x!=1) da[x].f++;
    da[x].del=da[x].g-da[x].f;
}
int main()
{
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
        scanf("%d",&a[i]);
    int u,v;
    for(int i=1;i<n;i++){
        scanf("%d%d",&u,&v);
        add(u,v); add(v,u);
    }
    dfs(1);
    printf("%d\n",da[1].g);
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值