zoukankan      html  css  js  c++  java
  • 【题解】[Codeforces 815C] CF815C Karen and Supermarket【树形DP】

    题目链接

    题意

    (n) 个商品呈有根树结构。每个商品有价格 (c_i)。若其父亲使用了优惠券,自己可以使用优惠券。给定 (m),问 (m) 元至多买多少个商品。(nleq 5000)(c_i,d_i,mleq 10^9)

    题解

    (f[i,j,0 /1]) 为考虑 (i) 号点的子树、买了 (j) 件商品,自己是否使用优惠券时的最小花费。

    #include<bits/stdc++.h>
    using namespace std;
    #define ll long long
    int getint(){
        int ans=0,f=1;
        char c=getchar();
        while(c<'0'||c>'9'){
            if(c=='-')f=-1;
            c=getchar();
        }
        while(c>='0'&&c<='9'){
            ans=ans*10+c-'0';
            c=getchar();
        }
        return ans*f;
    }
    const int N=5e3+10,mod=998244353,inv2=(mod+1)/2;
    struct bian{
        int e,n;
    };
    bian b[N<<1];
    int s[N],tot=0;
    void add(int x,int y){
        tot++;
        b[tot].e=y;
        b[tot].n=s[x];
        s[x]=tot;
    }
    
    ll f[N][N][2],g[N][2];
    int sz[N],c[N],d[N];
    void ss(int x){
        f[x][0][0]=0;
        f[x][1][0]=c[x];
        f[x][1][1]=c[x]-d[x];
        sz[x]=1;
        for(int i=s[x];i;i=b[i].n){
            int v=b[i].e;
            ss(v);
            memset(g,0x3f,sizeof(g));
            for(int j=0;j<=sz[x];j++){
                for(int k=0;k<=sz[v];k++){
                    g[j+k][0]=min({g[j+k][0],
                        f[x][j][0]+f[v][k][0]});
                    g[j+k][1]=min({g[j+k][1],
                        f[x][j][1]+f[v][k][1],
                        f[x][j][1]+f[v][k][0]});
                }
            }
            sz[x]+=sz[v];
            memcpy(f[x],g,sizeof(g));
        }
        // cerr<<">>>>>>> "<<x<<endl;
        // for(int i=0;i<=sz[x];i++)cerr<<"|| "<<i<<" "<<f[x][i][0]<<" "<<f[x][i][1]<<endl;
    }
    
    int main(){
        int n=getint(),b=getint();
        for(int i=1;i<=n;i++){
            c[i]=getint();
            d[i]=getint();
            if(i>=2)add(getint(),i);
        }
        memset(f,0x3f,sizeof(f));
        ss(1);
        int ans=0;
        for(int i=1;i<=n;i++)if(f[1][i][0]<=b||f[1][i][1]<=b)ans=i;
        cout<<ans;
    }
    
    
  • 相关阅读:
    Qt 交叉编译经典错误——头文件包含
    Linux-Qt使用QThread多线程isRunning标志量问题
    个人总结——C、C++指针传参和初始化字符空间
    ARM板设置开机自启动应用程序
    python--ModuleFoundError
    php输出错误屏蔽的函数
    类QQ账号生成阐述
    Python基础(四)—日期类型
    Python基础(三)—字典和集合
    Python基础(二)—列表和元组
  • 原文地址:https://www.cnblogs.com/wallbreaker5th/p/14214694.html
Copyright © 2011-2022 走看看