3354 [IOI2005]河流
题目描述
几乎整个Byteland王国都被森林和河流所覆盖。小点的河汇聚到一起,形成了稍大点的河。就这样,所有的河水都汇聚并流进了一条大河,最后这条大河流进了大海。这条大河的入海口处有一个村庄——名叫Bytetown。
在Byteland国,有n个伐木的村庄,这些村庄都座落在河边。目前在Bytetown,有一个巨大的伐木场,它处理着全国砍下的所有木料。木料被砍下后,顺着河流而被运到Bytetown的伐木场。Byteland的国王决定,为了减少运输木料的费用,再额外地建造k个伐木场。这k个伐木场将被建在其他村庄里。这些伐木场建造后,木料就不用都被送到Bytetown了,它们可以在运输过程中第一个碰到的新伐木场被处理。显然,如果伐木场座落的那个村子就不用再付运送木料的费用了。它们可以直接被本村的伐木场处理。
注:所有的河流都不会分叉,形成一棵树,根结点是Bytetown。
国王的大臣计算出了每个村子每年要产多少木料,你的任务是决定在哪些村子建设伐木场能获得最小的运费。其中运费的计算方法为:每一吨木料每千米1分钱。
输入输出格式
输入格式:
第一行包括两个数 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村子下游最近的村子(即i村子的父结点)(0≤vi≤n)
di——vi到i的距离(千米)。(1≤di≤10000)
保证每年所有的木料流到bytetown的运费不超过2,000,000,000分
50%的数据中n不超过20。
输出格式:
输出最小花费,单位为分。
输入输出样例
4 2
1 0 1
1 1 10
10 2 5
1 2 3
4
/*
用 f[i][j][k] 表示目前考虑第 i 个点, j 表示 i 所有的祖先中离 i 最近并且建了伐木场的节点, i 的儿子以及 i 的兄弟一共建了 k 个伐木场 的花费
决策:
1、不在这个节点建造伐木场。f[i][j][k]=min(f[i][j][k],f[leftson][i][l]+f[rightson][j][k-l-1])
2、 在这个节点建造伐木场。 f[i][j][k]=min(f[i][j][k],f[leftson][j][l]+f[rightson][j][k-l]+val[i]*(dis i..j))
*/
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
const int N=,M=;
const int inf=0x3f3f3f3f;
struct edge{
int lson,rson,num,dis;
}tr[N];
int n,K,top,dis[N],child[N],fa[N],stack[N],f[N][N][M];
void dfs(int x,int dl){
stack[++top]=x;
dis[x]=dl+tr[x].dis;
for(int i=tr[x].lson;i;i=tr[i].rson){
dfs(i,dis[x]);
}
}
int main(){
memset(fa,-,sizeof fa);//因为有0节点
scanf("%d%d",&n,&K);
for(int i=,w,v,d,t;i<=n;i++){
scanf("%d%d%d",&w,&v,&d);
/*慢!!!
if(!tr[v].lson) tr[v].lson=i;
else{
t=tr[v].lson;
for(;tr[t].rson;t=tr[t].rson);
tr[t].rson=i;
}*/
if(!child[v]) tr[v].lson=i;
else{
tr[child[v]].rson=i;
}
child[v]=i;
//多叉转二叉
tr[i].num=w;
tr[i].dis=d;
fa[i]=v;
}
dfs(,);//fa[0]=0;
memset(f,inf,sizeof f);
memset(f[],,sizeof f[]);//边界
for(int i=top;i>=;i--){
int now=stack[i];
int le=tr[now].lson;
int ri=tr[now].rson;
for(int j=fa[now];~j;j=fa[j]){//枚举父亲节点
for(int k=;k<=K;k++){
for(int l=;l<=k;l++){
if(f[le][j][l]!=inf&&f[ri][j][k-l]!=inf){//不选 i
f[now][j][k]=min(f[now][j][k],f[le][j][l]+f[ri][j][k-l]+tr[now].num*(dis[now]-dis[j]));
}
}
for(int l=;l<k;l++){//选 i
if(f[le][now][l]!=inf&&f[ri][j][k-l-]!=inf){
f[now][j][k]=min(f[now][j][k],f[le][now][l]+f[ri][j][k-l-]);
}
}
}
}
}
printf("%d",f[tr[].lson][][K]);
return ;
}
3354 [IOI2005]河流的更多相关文章
- 洛谷3354(IOI2005)河流——“承诺”
题目:https://www.luogu.org/problemnew/show/P3354 虽说是几个月前曾经讲过的题,但没有题解而自己(花了两个多小时)A了好高兴!!! 这是一个很好的套路:“承诺 ...
- [IOI2005]河流
Description Luogu3354 Solution 一道树形dp的题. 首先考虑转移,很简单,就是这个点做不做伐木场.为了方便转移,我们定义状态为\(f_{i,j,k}\)表示点\(i\)及 ...
- dp式子100个……
1. 资源问题1-----机器分配问题F[I,j]:=max(f[i-1,k]+w[i,j-k]) 2. 资源问题2------01背包问题F[I,j]:=max(f[i- ...
- dp方程
1. 资源问题1 -----机器分配问题 F[I,j]:=max(f[i-1,k]+w[i,j-k]) 2. 资源问题2 ------01背包问题 F[I,j]:=ma ...
- [LUOGU] P3354 [IOI2005]Riv 河流
题目描述 几乎整个Byteland王国都被森林和河流所覆盖.小点的河汇聚到一起,形成了稍大点的河.就这样,所有的河水都汇聚并流进了一条大河,最后这条大河流进了大海.这条大河的入海口处有一个村庄--名叫 ...
- BZOJ.1812.[IOI2005]Riv 河流(树形背包)
BZOJ 洛谷 这个数据范围..考虑暴力一些把各种信息都记下来.不妨直接令\(f[i][j][k][0/1]\)表示当前为点\(i\),离\(i\)最近的建了伐木场的\(i\)的祖先为\(j\),\( ...
- [IOI2005]River 河流
题目大意: 给定n个点的有根树,每条边有边权,每个点有点权w, 你要在k个点上建立伐木场,对于每个没有建伐木场的点x,令与它最近的祖先.有伐木场的点,为y,你需要支付dis(x,y)*w[x]的代价. ...
- 洛谷P3354 Riv河流 [IOI2005] 树型dp
正解:树型dp 解题报告: 传送门! 简要题意:有棵树,每个节点有个权值w,要求选k个节点,最大化∑dis*w,其中如果某个节点到根的路径上选了别的节点,dis指的是到达那个节点的距离 首先这个一看就 ...
- P3354 [IOI2005]Riv 河流
树形dp,设f[i][j][k]表示第i个点的子树中选择j个点作为伐木场,而且k是建了伐木场的最浅的i的祖先的情况下,最小的收益. 这种题还要练一下,咕咕 然后转移可以n4方做. // luogu-j ...
随机推荐
- java中XML操作:xml与string互转、读取XML文档节点及对XML节点增删改查
一.XML和String互转: 使用dom4j程式变得很简单 //字符串转XML String xmlStr = \"......\"; Document document = D ...
- 【Java】String和Date、Timestamp之间的转换
首先,定义一个Format的日期格式: SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 一.S ...
- 3D数学读书笔记——矩阵基础番外篇之线性变换
本系列文章由birdlove1987编写.转载请注明出处. 文章链接:http://blog.csdn.net/zhurui_idea/article/details/25102425 前面有一篇文章 ...
- RPC接口mock测试
转载:http://blog.csdn.net/ronghuanye/article/details/71124127 1 简介 Dubbo目前的应用已经越来越广泛.或者基于Dubbo二 ...
- Nodejs 模拟telnet
代码下载:https://files.cnblogs.com/files/xiandedanteng/nodejsTelnet.rar 效果: server.js代码: var net=require ...
- Sublime Text 3 文档
中文版:http://feliving.github.io/Sublime-Text-3-Documentation/ 英文版:http://www.sublimetext.com/docs/3/
- 【转载】 json字符串与JSON对象
ajax中,我们自己拼接的是一个JSON对象,以为它是无数据类型的,所以JS根据其格式默认其实对象, 你要是往后台发,要先把它装换成JSON字符. 从ajax的服务器发过的,一定是字符串,你想要把它解 ...
- LoadRunner读取关联数组的个数和内容
web_reg_save_param_ex( "ParamName=response_header1", "LB=Set-Cookie: ", "RB ...
- 微信小程序登录JAVA后台
代码地址如下:http://www.demodashi.com/demo/12736.html 登录流程时序登录流程时序 具体的登录说明查看 小程序官方API 项目的结构图: springboot项目 ...
- JAVA静态导入(inport static)详解
在Java 5中,import语句得到了增强,以便提供甚至更加强大的减少击键次数功能,虽然一些人争议说这是以可读性为代价的.这种新的特性成为静态导入. 当你想使用static成员时,可以使用静态导入( ...