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 贪吃的九头龙相关推荐

  1. NOI2002 贪吃的九头龙

    P2940 贪吃的九头龙 时间: 1000ms / 空间: 65536KiB / Java类名: Main 描述 贪吃的九头龙(dragon.pas/c/cpp) [问题描述] 传说中的九头龙是一种特 ...

  2. BSOJ 1480 贪吃的九头龙

    BSOJ 1480 贪吃的九头龙 NOI原题,下了数据,都过了.但是OJ现在挂了... 首先,脑袋的数量都是唬人的.如果至少3个脑袋的话,完全可以做到不让两个小头在一起(不过当只有2个头的时候得特别考 ...

  3. 【NOI2002】贪吃的九头龙

    Description 传说中的九头龙是一种特别贪吃的动物.虽然名字叫"九头龙",但这只是说它出生的时候有九个头,而在成长的过程中,它有时会长出很多的新头,头的总数会远大于九,当然 ...

  4. codevs贪吃的九头龙

    传说中的九头龙是一种特别贪吃的动物.虽然名字叫"九头龙",但这只是说它出生的时候有九个头,而在成长的过程中,它有时会长出很多的新头,头的总数会远大于九,当然也会有旧头因衰老而自己脱 ...

  5. codevs1746 贪吃的九头龙

    [问题描述] 传说中的九头龙是一种特别贪吃的动物.虽然名字叫"九头龙",但这只是说它出生的时候有九个头,而在成长的过程中,它有时会长出很多的新头,头的总数会远大于九,当然也会有旧头 ...

  6. “九头虫”病毒技术分析报告

    2019独角兽企业重金招聘Python工程师标准>>> ##一.背景介绍 近日,阿里移动安全收到多方用户反馈,手机中了一种难以清除的病毒.病毒一旦发作,设备将不断弹出广告,并自动下载 ...

  7. Medusa(美杜莎)和Hydra(九头蛇)快速入门手册:01

    今天主要是初步介绍一些Hydra和Medusa的分析和内容,旨在方便快速入门,这是第一部分Medusa,后面附带一些字典,之所以是写一起,我是觉得这两个都是不错的工具,不应该分开的,在这种思想下就汇总 ...

  8. 九头身美女_百度百科

    九头身美女_百度百科 九头身美女

  9. 密码爆破工具——九头蛇(hydra)

    九头蛇hydra 记得美国队长中的大反派hydra(九头蛇)组织吗? 今天介绍的这款渗透测试工具,也叫这个名字.​ hydra是著名组织thc的一款开源的暴力破解密码工具,功能非常强大 kali下是默 ...

最新文章

  1. CNN网络结构的发展:从LeNet到EfficientNet
  2. Java 里的thread (线程)简介
  3. JZOJ__Day 8:【普及模拟】马农
  4. python绘制不带颜色曲线图_Python数据可视化库-Matplotlib——折线图,子图绘制
  5. 我一哥们,在东莞和五名女孩被抓了.....
  6. npy一维数组如何对给出的索引进行反选
  7. 21天Jmeter打卡Day21生成HTML测试报告
  8. 如何在 macOS 上禁用 Adob​​e 后台进程,保存 CPU、内存和网络活动?
  9. 某公司ASP.NET应聘上机试题
  10. for in和for of的区别(转)
  11. 毕设题目:Matlab疾病识别与分类
  12. 转: 参数修饰符ref,out ,params的区别
  13. Unity基础(三)--动画系统
  14. 0基础学软件测试工程师好学吗?
  15. 王祥林 计算机专业英语答案,计算机专业英语 第3版 配套习题 作者 王祥林 陈静姣 模拟试题1.doc...
  16. python中sum函数的使用方法及实例_Python sum()用法及代码示例
  17. office2016—word不能使用输入法,只能输入英文问题
  18. 互联网日报 | 苹果10月14日再开发布会;消息称B站明年赴港二次上市;我国电子社保卡申领超2亿张...
  19. java学习记录十五:集合二Collections、Set、Map
  20. 国际智能制造联盟筹备会成功召开

热门文章

  1. 太有用了,自己有电脑的不看后悔一辈子
  2. WORD转换成PDF转换器2015官方版?
  3. Wmm的学习日记(文件包含漏洞.PHP伪协议)
  4. Android自定义View之跟随手指一起滑动的五色的小球
  5. WOWWEE ROVIO小车改造思路
  6. 双目测距--3 双目标定
  7. 为什么我讨厌 Scrum?
  8. 右键新建里面没有记事本和word以及excel简单解决
  9. STM32读写W25Q
  10. 读《拖延心理学》:战胜拖延症的方法