Description

现在我们的手头有N个软件,对于一个软件i,它要占用Wi的磁盘空间,它的价值为Vi。我们希望从中选择一些软件安装到一台磁盘容量为M计算机上,使得这些软件的价值尽可能大(即Vi的和最大)。

但是现在有个问题:软件之间存在依赖关系,即软件i只有在安装了软件j(包括软件j的直接或间接依赖)的情况下才能正确工作(软件i依赖软件j)。幸运的是,一个软件最多依赖另外一个软件。如果一个软件不能正常工作,那么它能够发挥的作用为0。

我们现在知道了软件之间的依赖关系:软件i依赖软件Di。现在请你设计出一种方案,安装价值尽量大的软件。一个软件只能被安装一次,如果一个软件没有依赖则Di=0,这时只要这个软件安装了,它就能正常工作。

Input

第1行:N,
M
 (0<=N<=100,
0<=M<=500)
      第2行:W1,
W2, ... Wi, ..., Wn (0<=Wi<=M

      第3行:V1,
V2, ..., Vi, ..., Vn  (0<=Vi<=1000

      第4行:D1,
D2, ..., Di, ..., Dn(0<=Di<=N,
Di≠i

Output

一个整数,代表最大价值。

Sample Input

3 10
5 5 6
2 3 4
0 1 1

Sample Output

5

HINT

 

Source

 
题解:
先tarjan缩下点,使其变成一棵树,然后我们就可以进行树上背包了
设f[u][i]表示选到u,用了空间i,得到的最大收益是多少
O(nm2)的转移显然,但其实可以优化到O(nm)
设u的一个儿子是v,则我们可以把f[u]作为初始状态直接付给f[v],然后就可以减少一个m的转移复杂度
注意把f[u]作为初始状态直接付给f[v]时,f[v]的第二维有下限(就是v及其所有祖先所占的空间和)
code:
  1. #include<cstdio>
  2. #include<iostream>
  3. #include<cmath>
  4. #include<cstring>
  5. #include<algorithm>
  6. using namespace std;
  7. char ch;
  8. bool ok;
  9. void read(int &x){
  10. ok=;
  11. for (ch=getchar();!isdigit(ch);ch=getchar()) if (ch=='-') ok=;
  12. for (x=;isdigit(ch);x=x*+ch-'',ch=getchar());
  13. if (ok) x=-x;
  14. }
  15. const int maxn=;
  16. const int maxm=;
  17. const int inf=;
  18. int n,m,a[maxn],b[maxn],x,ans;
  19. int f[maxn][maxm],g[maxm];
  20. int idx,dfn[maxn],low[maxn],stack[maxn],top,cnt,bel[maxn],siz[maxn],val[maxn],deg[maxn];
  21. bool in[maxn],bo[maxn];
  22. struct Graph{
  23. int tot,now[maxn],son[maxn],pre[maxn];
  24. void put(int a,int b){pre[++tot]=now[a],now[a]=tot,son[tot]=b;}
  25. void dfs(int u){
  26. dfn[u]=low[u]=++idx,stack[++top]=u,in[u]=;
  27. for (int p=now[u],v=son[p];p;p=pre[p],v=son[p])
  28. if (!dfn[v]) dfs(v),low[u]=min(low[u],low[v]);
  29. else if (in[v]) low[u]=min(low[u],dfn[v]);
  30. if (dfn[u]==low[u]){
  31. int v; ++cnt;
  32. do{v=stack[top--],bel[v]=cnt,siz[cnt]+=a[v],val[cnt]+=b[v],in[v]=;}while (u!=v);
  33. }
  34. }
  35. /*void dp(int u){
  36. bo[u]=1;
  37. memset(f[u],195,sizeof(f[u]));
  38. f[u][siz[u]]=val[u];
  39. for (int p=now[u],v=son[p];p;p=pre[p],v=son[p]) if (!bo[v]){
  40. dp(v);
  41. memcpy(g,f[u],sizeof(g));
  42. for (int i=0;i<=m;i++) for (int j=m;j>=i;j--) g[j]=max(g[j],f[v][i]+f[u][j-i]);
  43. memcpy(f[u],g,sizeof(g));
  44. }
  45. f[u][0]=max(f[u][0],0);
  46. }*/
  47. /*void dp(int u,int m){
  48. //cout<<u<<' '<<m<<endl;
  49. bo[u]=1;
  50. for (int p=now[u],v=son[p];p;p=pre[p],v=son[p]) if (!bo[v]){
  51. for (int i=0;i<=m;i++) f[v][i]=f[u][i];
  52. dp(v,m-siz[v]);
  53. for (int i=siz[v];i<=m;i++) f[u][i]=max(f[u][i],f[v][i-siz[v]]+val[v]);
  54. }
  55. }*/
  56. void dp(int u,int low){
  57. bo[u]=;
  58. for (int p=now[u],v=son[p];p;p=pre[p],v=son[p]) if (!bo[v]){
  59. for (int i=low;i<=m-siz[v];i++) f[v][i+siz[v]]=f[u][i]+val[v];
  60. dp(v,low+siz[v]);
  61. for (int i=low+siz[v];i<=m;i++) f[u][i]=max(f[u][i],f[v][i]);
  62. }
  63. }
  64. }G1,G2;
  65. int main(){
  66. read(n),read(m);
  67. for (int i=;i<=n;i++) read(a[i]);
  68. for (int i=;i<=n;i++) read(b[i]);
  69. for (int i=;i<=n;i++) read(x),G1.put(x,i);
  70. for (int i=;i<=n;i++) if (!dfn[i]) G1.dfs(i);
  71. for (int u=;u<=n;u++) for (int p=G1.now[u],v=G1.son[p];p;p=G1.pre[p],v=G1.son[p])
  72. if (bel[u]!=bel[v]) G2.put(bel[u],bel[v]),deg[bel[v]]++;
  73. for (int u=;u<=n;u++) if (!deg[bel[u]]) G2.put(bel[],bel[u]);
  74. //G2.dp(bel[0]);
  75. //G2.dp(bel[0],m);
  76. G2.dp(bel[],);
  77. for (int i=;i<=m;i++) ans=max(ans,f[bel[]][i]);
  78. printf("%d\n",ans);
  79. return ;
  80. }

bzoj2427: [HAOI2010]软件安装的更多相关文章

  1. [BZOJ2427][HAOI2010]软件安装(Tarjan+DP)

    2427: [HAOI2010]软件安装 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1987  Solved: 791[Submit][Statu ...

  2. bzoj2427:[HAOI2010]软件安装(Tarjan+tree_dp)

    2427: [HAOI2010]软件安装 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1053  Solved: 424[Submit][Statu ...

  3. BZOJ2427:[HAOI2010]软件安装(树形DP,强连通分量)

    Description 现在我们的手头有N个软件,对于一个软件i,它要占用Wi的磁盘空间,它的价值为Vi.我们希望从中选择一些软件安装到一台磁盘容量为M计算机上,使得这些软件的价值尽可能大(即Vi的和 ...

  4. 题解【bzoj2427 [HAOI2010]软件安装】

    Description 现在我们的手头有\(N\)个软件,对于一个软件\(i\),它要占用\(W_i\)的磁盘空间,它的价值为\(V_i\).我们希望从中选择一些软件安装到一台磁盘容量为\(M\)计算 ...

  5. [bzoj2427][HAOI2010]软件安装——强连通分量+树形DP

    题目大意 现在我们的手头有N个软件,对于一个软件i,它要占用Wi的磁盘空间,它的价值为Vi.我们希望从中选择一些软件安装到一台磁盘容量为M计算机上,使得这些软件的价值尽可能大(即Vi的和最大). 但是 ...

  6. [BZOJ2427]:[HAOI2010]软件安装(塔尖+DP)

    题目传送门 题目描述 现在我们的手头有N个软件,对于一个软件i,它要占用${W}_{i}$的磁盘空间,它的价值为${V}_{i}$.我们希望从中选择一些软件安装到一台磁盘容量为M计算机上,使得这些软件 ...

  7. [BZOJ2427][HAOI2010]软件安装-tarjan缩点-树上dp

    <题面> 这个题真伤人 之前Tarjan和树规都没学好,吃了不少亏,仔仔细细的搞了一天,收获颇丰 先来一个Tarjan的链接:$\mathbb{O}$ 题目的数据比较友好: $dp$不对: ...

  8. BZOJ2427: [HAOI2010]软件安装 tarjan+树形背包

    分析: 一开始我以为是裸的树形背包...之后被告知这东西...可能有环...什么!有环! 有环就搞掉就就可以了...tarjan缩点...建图记得建立从i到d[i]之后跑tarjan,因为这样才能判断 ...

  9. [BZOJ2427][HAOI2010]软件安装(tarjan+树形DP)

    如果依赖关系出现环,那么对于一个环里的点,要么都选要么都不选, 所以每个环可以当成一个点,也就是强连通分量 然后就可以构造出一颗树,然后树形背包瞎搞一下就行了 注意要搞一个虚拟节点当根节点 Code ...

随机推荐

  1. 动作之CCActionInstant(立即动作)家族

    立即动作就是不需要时间,马上就完成的动作.立即动作的共同基类是CCActionInstant.CCActionInstant的常用子类有: CCCallFunc:回调函数包装器 CCFlipX:X轴翻 ...

  2. Ubuntu远程桌面xrdp方法

    xrdp方式,该方法支持多用户登录并远程桌面. 首先在Ubuntu上安装GNOME界面,在终端输入命令: sudo apt-get install gnome-panel 安装完成后注销用户. 点击自 ...

  3. Android(java)学习笔记157:使用Dexdump等工具进行反编译

    使用Dex等工具进行反编译步骤: (1)首先找到Android软件安装包中的class.dex,把APK文件改名为".zip",然后解压缩其中的class.dex文件,这是Java ...

  4. 转:FORM:客制化Form的菜单栏和右鍵菜單

    Oracle EBS还允许客制化Form的菜单栏. 用户最多可以定义45个form-level的trigger,名称必须为SPECIALn, 其中SPECIAL1 to SPECIAL15属于Tool ...

  5. Ubuntu14.04服务器安装ftp

    随笔记录一下Ubuntu下安装ftp 1.远程连接登录服务器之后,输入sudo apt-get update 并回车.如果不运行该命令,直接安装vsftpd,可能会出现有一些软件包无法下载. 2.输入 ...

  6. c#面向对象编程基础

    1.  为什么要有面向对象? (1)       增加代码重用. (2)降低维护负担,将具备独特性质的代码封装起来,修改程序时,相互不会影响. 2.数据封装用来解决全局变量不易维护的问题. 3.多态: ...

  7. nyoj89 汉诺塔(二)

    题目网址 :http://acm.nyist.net/JudgeOnline/problem.php?pid=89 汉诺塔问题的经典结论: 把i个盘子从一个柱子整体移到另一个柱子最少需要步数是 2的i ...

  8. jquery - ul li click 无响应

    搞了很久, 发现对应jquery来说, 动态产生的ul li(其实不只是这个, 还有 table td等), 直接使用 $("#ul_div>li").click(funct ...

  9. 使用instsrv.exe+srvany.exe将应用程序安装为windows服务[转]

      转自:http://qingmu.blog.51cto.com/4571483/1248649 一.什么是instsrv.exe和srvany.exe instsrv.exe.exe和srvany ...

  10. Solr使用初探——SolrJ的使用

    二.SolrJ的使用 SolrJ覆盖了solr的全部功能,下面将自己在实际开发中所使用的程序粘贴出来并适当加以解释,由于本人比较菜,代码书写不是那么的精练,还请见谅. 1.  创建solrserver ...