给定一棵有根树,记$f_{i}$表示$i$的父亲,每一个点有一个代价$c_{i}$

给定常数$D$和$X$,再给每个点赋一个权值$v_{i}$($v_{i}\ge 0$),满足以下条件下最大化$\sum_{i=1}^{n}v_{i}$

条件:1.$\forall 2\le i\le n,v_{f_{i}}\le v_{i}\le v_{f_{i}}+D$;2.$\sum_{i=1}^{n}c_{i}v_{i}\le X$

$2\le n\le 50$,$1\le f_{i}<i$,$0\le D\le 10^{9}$,$1\le X,c_{i}\le 10^{9}$

构造$d_{i}=v_{i}-v_{f_{i}}$(特别的$d_{1}=v_{1}$),那么$v_{i}=d_{i}+v_{f_{i}}=...=\sum_{j为i祖先}d_{j}$

考虑每一个点的贡献,则有$\sum_{i=1}^{n}v_{i}=\sum_{i=1}^{n}d_{i}sz_{i}$和$\sum_{i=1}^{n}c_{i}v_{i}=\sum_{i=1}^{n}d_{i}sum_{i}$(其中$sz_{i}$为以$i$为根的子树大小,$sum_{i}$为以$i$为根子树中所有$c_{i}$的和)

可以看作一个背包,$n$个物品质量为$sum_{i}$,价值为$sz_{i}$,数量限制为$D$

先将所有物品按照“性价比”$\frac{sz_{i}}{sum_{i}}$从大到小排序,则若存在$x<y$满足$d_{x}+sz_{y}\le D$且$d_{y}\ge sz_{x}$,那么不妨令$d'_{y}=d_{y}-sz_{x}$且$d'_{x}=d_{x}+sz_{y}$,显然质量之和不变且价值不减少,因此最优解中必然不存在这类点对

由于$sz_{i}\le n$,将条件收缩为存在$x<y$满足$d_{x}+n\le D$且$d_{y}\ge n$

进一步的,将最终答案中的$d_{i}$分为三类:1.$D-n<d_{i}\le D$;2.$n\le d_{i}\le D-n$;3.$0\le d_{i}<n$,根据上述结论,任意第$i$类一定要在任意第$i+1$类前,且第2类数量不超过1(形象地,即构成了111……2333……)

对于第1类,转化为$D-n+1+d'_{i}$;对于第2类,转化为$d'_{i}+\lfloor\frac{d_{i}}{n}\rfloor n$,则都有$0\le d'_{i}<n$

先对$d'_{i}$背包,由于价值范围为$o(n^{3})$,那么令$f[i][j]$表示前$i$个物品,价值和为$j$的最小质量来dp即可,时间复杂度为$o(n^{4}\ln n)$或$o(n^{4})$(前者利用物品数量小于$\frac{n^{3}}{sz_{i}}$,后者用单调队列

枚举$\sum_{i=1}^{n}d'_{i}sz_{i}$(共$o(n^{3})$种),根据第$i$类要在第$i+1$类前的性质,对于剩下的部分贪心即可

(过程一眼看可能会有点假,注意$d'_{i}$是由$d_{i}$强制构造出来的,然后贪心根据的是结论)

特别的,对于$sz_{x}=n$这个位置(即原来的根),其没有数量限制,以第2类的方式构造$d'_{i}$,然后其贪心时没有上限

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 105
4 #define ll long long
5 struct ji{
6 int nex,to;
7 }edge[N];
8 int E,n,m,d,x,head[N],id[N],sz[N],f[2][N*N*N];
9 ll ans,sum[N];
10 bool cmp(int x,int y){
11 return sz[x]*sum[y]>sz[y]*sum[x];
12 }
13 void add(int x,int y){
14 edge[E].nex=head[x];
15 edge[E].to=y;
16 head[x]=E++;
17 }
18 void dfs(int k){
19 sz[k]=1;
20 for(int i=head[k];i!=-1;i=edge[i].nex){
21 dfs(edge[i].to);
22 sz[k]+=sz[edge[i].to];
23 sum[k]+=sum[edge[i].to];
24 }
25 }
26 int main(){
27 scanf("%d%d%d%lld",&n,&m,&d,&sum[1]);
28 memset(head,-1,sizeof(head));
29 for(int i=2;i<=n;i++){
30 scanf("%lld%d",&sum[i],&x);
31 add(x,i);
32 }
33 dfs(1);
34 for(int i=1;i<=n;i++)id[i]=i;
35 sort(id+1,id+n+1,cmp);
36 int mm=n*n*n;
37 for(int i=1;i<=mm;i++)f[0][i]=m+1;
38 for(int i=1;i<=n;i++){
39 int p=(i&1);
40 for(int j=0;j<=mm;j++){
41 f[p][j]=m+1;
42 for(int k=0;(k<=min(n,d))&&(k*sz[id[i]]<=j);k++)
43 f[p][j]=min((ll)f[p][j],f[p^1][j-k*sz[id[i]]]+k*sum[id[i]]);
44 }
45 }
46 for(int i=0;i<=mm;i++)
47 if (f[(n&1)][i]<=m){
48 int s=m-f[(n&1)][i];
49 ll tot=i;
50 for(int j=1;j<=n;j++)
51 if ((id[j]==1)||(sum[id[j]]*(d-n)>s)){
52 tot+=1LL*sz[id[j]]*(s/sum[id[j]]);
53 s-=sum[id[j]]*(s/sum[id[j]]);
54 }
55 else{
56 if (d<n)continue;
57 tot+=1LL*sz[id[j]]*(d-n);
58 s-=sum[id[j]]*(d-n);
59 }
60 ans=max(ans,tot);
61 }
62 printf("%lld",ans);
63 }

[atARC096F]Sweet Alchemy的更多相关文章

  1. *AtCoder Regular Contest 096F - Sweet Alchemy

    $n \leq 50$的树,每个点有权值,现要选点(可多次选一个点)使点数尽量多,如下限制:选的总权值不超过$C \leq 1e9$:$c_i$表示$i$选的次数,$p_i$表示$i$的父亲,那么$c ...

  2. AT4120-[ARC096D]Sweet Alchemy【贪心,背包】

    正题 题目链接:https://www.luogu.com.cn/problem/AT4120 题目大意 给出\(n\)个物品和一个容量\(m\),第\(i\)个物品体积为\(c_i\).除了第一个物 ...

  3. Atcoder Regular Contest 096 D - Sweet Alchemy(贪心+多重背包)

    洛谷题面传送门 & Atcoder 题面传送门 由于再过 1h 就是 NOI 笔试了所以题解写得会略有点简略. 考虑差分,记 \(b_i=c_i-c_{fa_i}\),那么根据题意有 \(b_ ...

  4. Atcoder 乱做

    最近感觉自己思维僵化,啥都不会做了-- ARC103 F Distance Sums 题意 给定第 \(i\) 个点到所有点的距离和 \(D_i\) ,要求构造一棵合法的树.满足第 \(i\) 个点到 ...

  5. 【AtCoder】ARC096(C - F)

    听说日本题思维都很棒,去涨涨智商qwq C - Half and Half 题解 枚举买多少个AB披萨也行 但是关于买x个AB披萨最后的总花费是个单峰函数,可以三分 这题有点像六省联考2017D1T1 ...

  6. AtCoder Regular Contest 096

    AtCoder Regular Contest 096 C - Many Medians 题意: 有A,B两种匹萨和三种购买方案,买一个A,买一个B,买半个A和半个B,花费分别为a,b,c. 求买X个 ...

  7. 使用wireshark抓包分析浏览器无法建立WebSocket连接的问题(server为Alchemy WebSockets组件)

    工作时使用了Websocket技术,在使用的过程中发现,浏览器(Chrome)升级后可能会导致Websocket不可用,更换浏览器后可以正常使用. 近日偶尔一次在本地调试,发现使用相同版本的Chrom ...

  8. Sweet Alert

    http://www.dglives.com/demo/sweetalert-master/example/ Sweet Alert A beautiful replacement for Javas ...

  9. 【转】Alchemy的使用和多项式批量计算的优化

    原文:http://www.cnblogs.com/flash3d/archive/2012/01/30/2332158.html ================================== ...

随机推荐

  1. 程序员微机课系列—我的nodejs多版本管理方法

    nodejs的多版本配置对于我来说一直都是一个较为头疼的事情.本人的开发工作会涉及electron以及前端,对于工作中使用的npm包(点名node-sqlite3和node-sass)在某些情况下,会 ...

  2. 题解 有标号DAG计数

    题目传送门 题目大意 给出\(n\),求出对于任意\(t\in[1,n]\),点数为\(t\)的弱联通\(\texttt{DAG}\)个数.答案对\(998244353\)取模. \(n\le 10^ ...

  3. hdu3507 斜率优化学习笔记(斜率优化+dp)

    QWQ菜的真实. 首先来看这个题. 很显然能得到一个朴素的\(dp\)柿子 \[dp[i]=max(dp[i],dp[j]+(sum[i]-sum[j])^2) \] 但是因为\(n\le 50000 ...

  4. 错误 Unresolved reference 'AF_INET' 解决办法

    错误代码如下: import socketserer_socket = socket.socket(AF_INET, SOCK_DGAM) 错误信息: 原因分析: 1.AF_INET,SOCK_DGA ...

  5. 【UE4】GAMES101 图形学作业5:光线与物体相交(球、三角面)

    总览 在这部分的课程中,我们将专注于使用光线追踪来渲染图像.在光线追踪中最重要的操作之一就是找到光线与物体的交点.一旦找到光线与物体的交点,就可以执行着色并返回像素颜色. 在这次作业中,我们要实现两个 ...

  6. kivy布局(一)

    # import kivy from kivy.app import App # 导入应用 from kivy.uix.label import Label # 导入标签 from kivy.uix. ...

  7. Scrum Meeting 0529

    零.说明 日期:2021-5-29 任务:简要汇报七日内已完成任务,计划后两日完成任务 一.进度情况 组员 负责 七日内已完成的任务 后两日计划完成的任务 困难 qsy PM&前端 完成后端管 ...

  8. Beta阶段第十次会议

    Beta阶段第十次会议 时间:2020.5.26 完成工作 姓名 完成工作 难度 完成度 ltx 1.修正小程序新闻bug2.修正小程序认证bug 中 80% xyq 1.上传信息编辑部分代码到服务器 ...

  9. oo第四次博客-UML暨学期总结

    一. 本单元两次作业架构设计 这两次作业实际上难度不大,不存在算法上的难题,大部分时间都是用在处理UML图中各个元素的关系上. 第一次UML主要处理UML类图.有UMLclass,UMLinterfa ...

  10. proto3语法记录

    protobuf 是谷歌的语言无关,平台无关,可扩展的,高效的结构化数据序列化机制,比xml和json的序列化的速度更快,此处记录一下 proto3 的语法,防止以后忘记. 注意:proto3 语法需 ...