Description

几乎整个Byteland王国都被森林和河流所覆盖。小点的河汇聚到一起,形成了稍大点的河。就这样,所有的河水都汇聚并流进了一条大河,最后这条大河流进了大海。这条大河的入海口处有一个村庄——名叫Bytetown 在Byteland国,有n个伐木的村庄,这些村庄都座落在河边。目前在Bytetown,有一个巨大的伐木场,它处理着全国砍下的所有木料。木料被砍下后,顺着河流而被运到Bytetown的伐木场。Byteland的国王决定,为了减少运输木料的费用,再额外地建造k个伐木场。这k个伐木场将被建在其他村庄里。这些伐木场建造后,木料就不用都被送到Bytetown了,它们可以在 运输过程中第一个碰到的新伐木场被处理。显然,如果伐木场座落的那个村子就不用再付运送木料的费用了。它们可以直接被本村的伐木场处理。 注意:所有的河流都不会分叉,也就是说,每一个村子,顺流而下都只有一条路——到bytetown。 国王的大臣计算出了每个村子每年要产多少木料,你的任务是决定在哪些村子建设伐木场能获得最小的运费。其中运费的计算方法为:每一块木料每千米1分钱。 编一个程序: 1.从文件读入村子的个数,另外要建设的伐木场的数目,每年每个村子产的木料的块数以及河流的描述。 2.计算最小的运费并输出。

Input

第一行 包括两个数 n(2<=n<=100),k(1<=k<=50,且 k<=n)。n为村庄数,k为要建的伐木场的数目。除了bytetown外,每个村子依次被命名为1,2,3……n,bytetown被命名为0。 接下来n行,每行包涵3个整数 wi——每年i村子产的木料的块数 (0<=wi<=10000) vi——离i村子下游最近的村子(或bytetown)(0<=vi<=n) di——vi到i的距离(km)。(1<=di<=10000) 保证每年所有的木料流到bytetown的运费不超过2000,000,000分 50%的数据中n不超过20。

Output

输出最小花费,精确到分。

Sample Input

4 2
1 0 1
1 1 10
10 2 5
1 2 3

Sample Output

4
    分析:不难看出f[i][j]的转移方程表示在以i为根结建了j个木场的最优值,然后转一转发现并没有*用,于是考虑加一维,因为原方程没有考虑到距离,所以加一维表示i到rt的距离,rt表示离i最近的木场,然后记忆化搜索一遍j就ok了。

# include <iostream>
# include <cstdio>
# include <cstring>
# include <cmath>
# include <algorithm>
# include <list>
using namespace std;
int read()
{int i=0,f=1;char c=getchar();while(c<'0'||c>'9') {if(c=='-') f=-1;c=getchar();}while(c>='0'&&c<='9'){i=(i<<3)+(i<<1)+c-'0';c=getchar();}return i*f;
}
int l[205],r[205],dis[205],w[205],val[205],f[205][205][205];
int n,k,m,x,y,z;
inline void find(int u)
{for(int v=l[u];v;v=r[v]){dis[v]=dis[u]+w[v];find(v);}
}
int DFS(int i,int j,int rt)
{if(f[i][j][rt]!=-1) return f[i][j][rt];f[i][j][rt]=1e9+7;for(int e=0;e<=j;++e){int res=(dis[i]-dis[rt])*val[i];if(l[i]) res+=DFS(l[i],e,rt);if(r[i]) res+=DFS(r[i],j-e,rt);f[i][j][rt]=min(res,f[i][j][rt]);if(e<j){res=0;if(l[i]) res+=DFS(l[i],e,i);if(r[i]) res+=DFS(r[i],j-e-1,rt);f[i][j][rt]=min(res,f[i][j][rt]);}}return f[i][j][rt];
}
int main()
{n=read(),k=read();for(int i=1;i<=n;++i){val[i]=read();x=read();w[i]=read();y=l[x];l[x]=i;r[i]=y;}find(0);memset(f,-1,sizeof(f));  printf("%d\n",DFS(0,k,0));}

BZOJ1812 RIV 树形dp相关推荐

  1. [bzoj1812][IOI2006]riv_多叉树转二叉树_树形dp

    riv bzoj-1812 IOI-2006 题目大意:给定一棵n个点树,要求在上面建立k个收集站.点有点权,边有边权,整棵树的代价是每个点的点权乘以它和它的最近的祖先收集站的距离积的和. 注释:$1 ...

  2. 【bzoj 1812】[Ioi2005]riv(树形dp)

    1812: [Ioi2005]riv Time Limit: 10 Sec  Memory Limit: 64 MB Submit: 433  Solved: 246 [Submit][Status] ...

  3. BNUOJ 52305 Around the World 树形dp

    题目链接: https://www.bnuoj.com/v3/problem_show.php?pid=52305 Around the World Time Limit: 20000msMemory ...

  4. [树形dp] Jzoj P5233 概率博弈

    Description 小A和小B在玩游戏.这个游戏是这样的: 有一棵n个点的以1为根的有根树,叶子有权值.假设有m个叶子,那么树上每个叶子的权值序列就是一个1->m 的排列. 一开始在1号点有 ...

  5. fwt优化+树形DP HDU 5909

    1 //fwt优化+树形DP HDU 5909 2 //见官方题解 3 // BestCoder Round #88 http://bestcoder.hdu.edu.cn/ 4 5 #include ...

  6. BZOJ 1040 ZJOI2008 骑士 树形DP

    题目大意:给定一个基环树林,每一个点上有权值,要求选择一个权值和最大的点集,要求点集中的随意两个点之间不能直接相连 最大点独立集--考虑到n<=100W,网络流铁定跑不了,于是我们考虑树形DP ...

  7. POJ 3342 树形DP+Hash

    这是很久很久以前做的一道题,可惜当时WA了一页以后放弃了. 今天我又重新捡了起来.(哈哈1A了) 题意: 没有上司的舞会+判重 思路: hash一下+树形DP 题目中给的人名hash到数字,再进行运算 ...

  8. [NC15748]旅游 树形dp基础

    菜鸡第一次接触树形dp这个东西,不过这个东西还是很好理解的(可能是因为模板题吧) 个人感觉,相比线性dp,树形dp的状态转移方程更加的直观,难点主要是在"树"的结构上比较麻烦. 题 ...

  9. 容斥 + 树形dp ---- 2021 icpc 沈阳 L Perfect Matchings

    题目链接 题目大意: 就是给你一个2n2n2n个点的完全图,从这个图里面抽出2n−12n-12n−1条边,这些边形成一颗树,现在问你剩下的图里面点进行完美匹配有多少种方案? 解题思路: 一开始被完美匹 ...

最新文章

  1. Google Brain大牛Jeff dean视频
  2. starting mysql. success!_启动mysql报错解决问题过程
  3. mysql 分页算法_MySQL高效的分页算法
  4. Spring-jdbc:JdbcTemplate使用简介
  5. 【题解】跳房子-C++
  6. 网站域名备案时需要什么资料
  7. hustoj Runtime Error (运行错误)的解决方法
  8. vivox6Android版本,vivo X6的手机系统是什么?vivo X6能升级安卓5.0吗?
  9. -lavutil -lavcodec -lavdevice -lavfilter -lavformat链接失败,换用-lffmpeg
  10. Atitit zip解压文件 java use apache ant.jar C:\0wkspc\hislog\src\main\java\com\attilax\compress\ZipUt
  11. 本地存储和服务器存储
  12. java安装后怎么打开_java安装后怎么打开教程
  13. 《软件设计师教程最新版(第三版》
  14. 8021什么意思_无线网络标准IEEE802.11n是什么意思
  15. 谷歌chrome浏览器突然不记录登录状态,怎么办
  16. HNOI2018退役记
  17. 逆势高速增长,毫末征战三年诠释量产为王
  18. 白话空间统计二十七:统计学七支柱之空间统计版本(二)聚合(2)
  19. 【点宽专栏】国信证券——关于量化选股之聚类分析的探讨
  20. 无聊创意12306改变

热门文章

  1. “牌面”养成记4:阅读顺序,工具,以及小成果
  2. rt linux 测试,Ubuntu下测试RT-Linux的性能
  3. 2022实体经济寒冬,商家如何通过短视频平台寻找突破口
  4. 转 兵无常势 水无常形 贴
  5. 软考数据库工程师2021下午题@故障恢复解析
  6. 深度解读《关于防范NFT相关金融风险倡议》透露哪些监管信号与数字藏品新发展之路?
  7. Windows 7安装ATI驱动
  8. java用代码实现星期菜谱_基于JAVA的菜谱大全接口调用代码实例
  9. Python 猜100以内数字
  10. mysql 同步复制 半同步复制_一文看懂MySQL的异步复制、全同步复制与半同步复制...