vijos 1523 贪吃的九头龙
http://www.elijahqi.win/archives/1191
背景
安徽省芜湖市第二十七中学测试题
NOI 2002 贪吃的九头龙(dragon)
Description:Official
Data:Official
Program:Converted by JackDavid127
描述
传说中的九头龙是一种特别贪吃的动物。虽然名字叫“九头龙”,但这只是说它出生的时候有九个头,而在成长的过程中,它有时会长出很多的新头,头的总数会远大于九,当然也会有旧头因衰老而自己脱落。
有一天,有M个脑袋的九头龙看到一棵长有N个果子的果树,喜出望外,恨不得一口把它全部吃掉。可是必须照顾到每个头,因此它需要把N个果子分成M组,每组至少有一个果子,让每个头吃一组。
这M个脑袋中有一个最大,称为“大头”,是众头之首,它要吃掉恰好K个果子,而且K个果子中理所当然地应该包括唯一的一个最大的果子。果子由N-1根树枝连接起来,由于果树是一个整体,因此可以从任意一个果子出发沿着树枝“走到”任何一个其他的果子。
对于每段树枝,如果它所连接的两个果子需要由不同的头来吃掉,那么两个头会共同把树枝弄断而把果子分开;如果这两个果子是由同一个头来吃掉,那么这个头会懒得把它弄断而直接把果子连同树枝一起吃掉。当然,吃树枝并不是很舒服的,因此每段树枝都有一个吃下去的“难受值”,而九头龙的难受值就是所有头吃掉的树枝的“难受值”之和。
九头龙希望它的“难受值”尽量小,你能帮它算算吗?
格式
输入格式
输入的第1行包含三个整数N(1<=N<=300),M(2<=M<=N),K(1<=K<=N)。N个果子依次编号1,2,…,N,且最大的果子的编号总是1。第2行到第N行描述了果树的形态,每行包含三个整数a(1<=a<=N),b(1<=b<=N),c(0<=c<=105),表示存在一段难受值为c的树枝连接果子a和果子b。
输出格式
输出仅有一行,包含一个整数,表示在满足“大头”的要求的前提下,九头龙的难受值的最小值。如果无法满足要求,输出-1。
样例1
样例输入1
8 2 4
1 2 20
1 3 4
1 4 13
2 5 10
2 6 12
3 7 15
3 8 5
Copy
样例输出1
4
Copy
提示
树形动态规划
来源
安徽省芜湖市第二十七中学测试题
NOI 2002 贪吃的九头龙(dragon)
Description:Official
Data:Official
Program:Converted by JackDavid127
对于这题状态数众多 首先我们考虑将多叉树转换为二叉树
转换方法就是 我新读入一个儿子那么我就把我的老儿子过度给这个儿子的右子树
相当于每个点都是左手儿子右手兄弟
设dp[x][k1][v] 设现在x这个位置 还得吃k1个果子,v表示上一个是否被吃掉
首先提一下建树 将多叉树转为二叉树 左儿子右兄弟 tree[y].right=tree[x].left;tree[x].left=y;
然后直接dp就可以了 dp[x][k1[v]={取我这个点,或者不取
注意转移状态的时候i-1可能会越界 如果m==2的情况我要是两个果子都不吃 那么小头一定要吃 所以难受值也会增加
我每次去枚举给儿子这么多果子 剩余的果子分给兄弟 取一下加和的最小值即可
#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 330
#define inf 0x3f3f3f3f
using namespace std;
inline char gc(){static char now[1<<16],*T,*S;if (S==T){T=(S=now)+fread(now,1,1<<16,stdin);if (S==T) return EOF;}return *S++;
}
inline int read(){int x=0;char ch=gc();while (ch<'0'||ch>'9') ch=gc();while (ch<='9'&&ch>='0') {x=x*10+ch-'0';ch=gc();}return x;
}
int n,m,k,fa[N],num,h[N];
struct node{int left,right,x;
}tree[N];
int dp[N][N][N];int size[N];
void dfs(int x){if (tree[x].left) dfs(tree[x].left);if (tree[x].right) dfs(tree[x].right);size[x]=size[tree[x].left]+size[tree[x].right]+1;
}
void f(int x,int k1,int v){if (k1<0) return;if (!x&&!k1){dp[x][k1][v]=0;return;}if (!x) {dp[x][k1][v]=inf;return;}dp[x][k1][v]=inf;for (int i=0;i<=min(size[x],k1);++i){int tmp1,tmp2,tmp3;if (dp[tree[x].left][i-1][1]==-1&&i-1>=0) f(tree[x].left,i-1,1);if(i-1>=0) tmp1=dp[tree[x].left][i-1][1]+(v==1)*tree[x].x;else tmp1=inf;if (dp[tree[x].left][i][0]==-1) f(tree[x].left,i,0);tmp2=dp[tree[x].left][i][0]+(m==2)*(v==0)*tree[x].x;if (dp[tree[x].right][k1-i][v]==-1) f(tree[x].right,k1-i,v);tmp3=dp[tree[x].right][k1-i][v];tmp1=min(tmp1,tmp2);dp[x][k1][v]=min(dp[x][k1][v],tmp1+tmp3);}
}
int main(){freopen("dragon.in","r",stdin);n=read();m=read();k=read();if (n-k<m-1){printf("-1");return 0;}for (int i=1;i<n;++i){int x=read(),y=read(),z=read(); tree[y].right=tree[x].left;tree[x].left=y;tree[y].x=z;}dfs(1);memset(dp,-1,sizeof(dp));f(tree[1].left,k-1,1);printf("%d",dp[tree[1].left][k-1][1]);return 0;
}
vijos 1523 贪吃的九头龙相关推荐
- NOI2002 贪吃的九头龙
P2940 贪吃的九头龙 时间: 1000ms / 空间: 65536KiB / Java类名: Main 描述 贪吃的九头龙(dragon.pas/c/cpp) [问题描述] 传说中的九头龙是一种特 ...
- BSOJ 1480 贪吃的九头龙
BSOJ 1480 贪吃的九头龙 NOI原题,下了数据,都过了.但是OJ现在挂了... 首先,脑袋的数量都是唬人的.如果至少3个脑袋的话,完全可以做到不让两个小头在一起(不过当只有2个头的时候得特别考 ...
- 【NOI2002】贪吃的九头龙
Description 传说中的九头龙是一种特别贪吃的动物.虽然名字叫"九头龙",但这只是说它出生的时候有九个头,而在成长的过程中,它有时会长出很多的新头,头的总数会远大于九,当然 ...
- codevs贪吃的九头龙
传说中的九头龙是一种特别贪吃的动物.虽然名字叫"九头龙",但这只是说它出生的时候有九个头,而在成长的过程中,它有时会长出很多的新头,头的总数会远大于九,当然也会有旧头因衰老而自己脱 ...
- codevs1746 贪吃的九头龙
[问题描述] 传说中的九头龙是一种特别贪吃的动物.虽然名字叫"九头龙",但这只是说它出生的时候有九个头,而在成长的过程中,它有时会长出很多的新头,头的总数会远大于九,当然也会有旧头 ...
- “九头虫”病毒技术分析报告
2019独角兽企业重金招聘Python工程师标准>>> ##一.背景介绍 近日,阿里移动安全收到多方用户反馈,手机中了一种难以清除的病毒.病毒一旦发作,设备将不断弹出广告,并自动下载 ...
- Medusa(美杜莎)和Hydra(九头蛇)快速入门手册:01
今天主要是初步介绍一些Hydra和Medusa的分析和内容,旨在方便快速入门,这是第一部分Medusa,后面附带一些字典,之所以是写一起,我是觉得这两个都是不错的工具,不应该分开的,在这种思想下就汇总 ...
- 九头身美女_百度百科
九头身美女_百度百科 九头身美女
- 密码爆破工具——九头蛇(hydra)
九头蛇hydra 记得美国队长中的大反派hydra(九头蛇)组织吗? 今天介绍的这款渗透测试工具,也叫这个名字. hydra是著名组织thc的一款开源的暴力破解密码工具,功能非常强大 kali下是默 ...
最新文章
- CNN网络结构的发展:从LeNet到EfficientNet
- Java 里的thread (线程)简介
- JZOJ__Day 8:【普及模拟】马农
- python绘制不带颜色曲线图_Python数据可视化库-Matplotlib——折线图,子图绘制
- 我一哥们,在东莞和五名女孩被抓了.....
- npy一维数组如何对给出的索引进行反选
- 21天Jmeter打卡Day21生成HTML测试报告
- 如何在 macOS 上禁用 Adob​​e 后台进程,保存 CPU、内存和网络活动?
- 某公司ASP.NET应聘上机试题
- for in和for of的区别(转)
- 毕设题目:Matlab疾病识别与分类
- 转: 参数修饰符ref,out ,params的区别
- Unity基础(三)--动画系统
- 0基础学软件测试工程师好学吗?
- 王祥林 计算机专业英语答案,计算机专业英语 第3版 配套习题 作者 王祥林 陈静姣 模拟试题1.doc...
- python中sum函数的使用方法及实例_Python sum()用法及代码示例
- office2016—word不能使用输入法,只能输入英文问题
- 互联网日报 | 苹果10月14日再开发布会;消息称B站明年赴港二次上市;我国电子社保卡申领超2亿张...
- java学习记录十五:集合二Collections、Set、Map
- 国际智能制造联盟筹备会成功召开