T2 .tyvj   P1523贪吃的九头龙

描述

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

有一天,有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

样例输出1

4

分析:
爆搜搜了20分
正解:树形DP题目可以分为m=2和m>2的情况,因为当m>2是,小头一定不会产生难受值,只关心大头就可以,而当m=2时,小头要选择出大头选的k个之外的所有果子,把题目当作两个头来做。注意事先用左儿子右兄弟表示法转换成一棵二叉树。fa代表父亲,val是难受值,ch是左儿子和右兄弟。
代码:
#include<cstdio>
#include<iostream>
#include<cstring>
#define M 310
#define INF 100000000
using namespace std;
int fa[M],val[M][M],ch[M][3],f[M][M][2],head[M],n,m,k;
struct node
{int v,pre,t;
};node e[M*2];
void add(int i,int x,int y,int z)
{e[i].v=y;e[i].t=z;e[i].pre=head[x];head[x]=i;
}
void build(int x)
{for(int i=head[x];i;i=e[i].pre)if(!fa[e[i].v]){fa[e[i].v]=x;if(!ch[x][1])ch[x][1]=e[i].v;else{int f=ch[x][1];while(ch[f][2])f=ch[f][2];ch[f][2]=e[i].v;}build(e[i].v);}
}
int dfs1(int now,int sum,int p)//now是当前节点,sum是大头还有几个没选,p是now的父亲有没有选
{if(f[now][sum][p]!=-1)return f[now][sum][p];if(now==0&&sum>0)return INF;if(now==0&&sum==0)return 0;int minn=INF;for(int i=0;i<=sum;i++)//大头不选
    {int tot=0;if(p==0)tot+=val[now][fa[now]];tot+=dfs1(ch[now][1],i,0)+dfs1(ch[now][2],sum-i,p);minn=min(minn,tot);}for(int i=0;i<sum;i++)//大头选
    {int tot=0;if(p==1)tot+=val[now][fa[now]];tot+=dfs1(ch[now][1],i,1)+dfs1(ch[now][2],sum-i-1,p);minn=min(minn,tot);}f[now][sum][p]=minn;return f[now][sum][p];
}
int dfs2(int now,int sum,int p)//now是当前节点,sum是大头还有几个没选,p是now的父亲有没有选
{if(f[now][sum][p]!=-1)return f[now][sum][p];if(sum==0)return 0;if(now==0)return INF;int minn=INF;for(int i=0;i<=sum;i++)//大头不选 minn=min(minn,dfs2(ch[now][1],i,0)+dfs2(ch[now][2],sum-i,p));for(int i=0;i<sum;i++)//大头选
    {int tot=0;if(p==1)tot+=val[now][fa[now]];tot+=dfs2(ch[now][1],i,1)+dfs2(ch[now][2],sum-i-1,p);minn=min(minn,tot);}f[now][sum][p]=minn;return f[now][sum][p];
}
int main()
{freopen("jh.in","r",stdin);memset(f,-1,sizeof(f));scanf("%d%d%d",&n,&m,&k);if(n-k<m-1){printf("-1");return 0;}for(int i=1;i<=n;i++){int x,y,z;scanf("%d%d%d",&x,&y,&z);val[x][y]=val[y][x]=z;add(i*2-1,x,y,z);add(i*2,y,x,z);}fa[1]=1;build(1);if(m==2)//考虑大头小头一起选
    {int ans=INF;for(int i=0;i<k;i++)ans=min(ans,dfs1(ch[1][1],i,1)+dfs1(ch[1][2],k-i-1,1));printf("%d",ans);}else//只考虑选大头的情况
    {int ans=INF;for(int i=0;i<k;i++)ans=min(ans,dfs2(ch[1][1],i,1)+dfs2(ch[1][2],k-i-1,1));printf("%d",ans);}return 0;
}

View Code

转载于:https://www.cnblogs.com/harden/p/5777345.html

贪吃的九头龙(tyvj P1523)相关推荐

  1. NOI2002 贪吃的九头龙

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

  2. vijos 1523 贪吃的九头龙

    http://www.elijahqi.win/archives/1191 背景 安徽省芜湖市第二十七中学测试题 NOI 2002 贪吃的九头龙(dragon) Description:Officia ...

  3. BSOJ 1480 贪吃的九头龙

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

  4. 【NOI2002】贪吃的九头龙

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

  5. codevs贪吃的九头龙

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

  6. codevs1746 贪吃的九头龙

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

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

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

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

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

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

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

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

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

最新文章

  1. maven设置jdk版本(全局设置和工程设置)
  2. linux中的文件,文件夹,链接的权限划分
  3. 论文浅尝 | AMUSE: 基于 RDF 数据的多语言问答语义解析方法
  4. free() 是如何释放不同内存区块大小的指针?
  5. gdal mysql乱码_GDAL读取S-57海图数据中文属性值乱码问题解决(续)
  6. 垃圾回收机制GC知识再总结兼谈如何用好GC(转)
  7. python自动轨迹绘制七边形_前端系列——canvas实现按住鼠标移动绘制出轨迹
  8. SQL数据导入mongodb
  9. windows 系统 system 进程占用80端口
  10. 【ceph】ceph osd启动及peering过程中osdmap相关加载和更新流程
  11. 记录一个android性能优化宝藏级总结
  12. 开个水果店选址在哪,水果店选址的小窍门
  13. c# distinct用法
  14. Quartus生成原理图
  15. 【论文翻译】DANN的改进ADDA Multimodal Vigilance Estimation with Adversarial Domain Adaptation Networks
  16. php正则匹配字符_PHP正则表达式匹配字符的方法汇总
  17. 数字后端 - STA
  18. P4735 最大异或和 可持久化trie树
  19. 实时票房 麦谈帮API数据接口
  20. 对 Error-State Kalman Filter 的理解

热门文章

  1. 【阿里云服务器】ECS云服务器新手上路
  2. 网易微专业Android实战教程
  3. 邓白氏编码的申请流程
  4. 小米笔记本U盘win10换win7系统操作教程
  5. 4.0寸86盒显示屏调试(一)
  6. 渗透测试试题-----web方面知识点
  7. 中国移动mda移动桌面助手
  8. Invocation failed Server returned invalid Response.或java.io.IOException: Server returned invalid Res
  9. org.apache.kafka.clients.consumer.OffsetOutOfRangeException: Offsets out of range with no configured
  10. TSE无线通信(铺垫)