博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【Luogu1272】重建道路(动态规划)
阅读量:4330 次
发布时间:2019-06-06

本文共 1432 字,大约阅读时间需要 4 分钟。

【Luogu1272】重建道路(动态规划)

题面

题目描述

一场可怕的地震后,人们用N个牲口棚(1≤N≤150,编号1..N)重建了农夫John的牧场。由于人们没有时间建设多余的道路,所以现在从一个牲口棚到另一个牲口棚的道路是惟一的。因此,牧场运输系统可以被构建成一棵树。John想要知道另一次地震会造成多严重的破坏。有些道路一旦被毁坏,就会使一棵含有P(1≤P≤N)个牲口棚的子树和剩余的牲口棚分离,John想知道这些道路的最小数目。

输入输出格式
输入格式:

第1行:2个整数,N和P

第2..N行:每行2个整数I和J,表示节点I是节点J的父节点。

输出格式:

单独一行,包含一旦被破坏将分离出恰含P个节点的子树的道路的最小数目。

输入输出样例

输入样例#1:

11 6

1 2
1 3
1 4
1 5
2 6
2 7
2 8
4 9
4 10
4 11

输出样例#1:

2

题解

树型DP

\(f[i][j]\)表示当前以\(i\)为根节点,保留\(j\)个节点的最小代价
转移有所有子树的值转移过来
其中\(f[i][1]=degree[i]\),其中\(degree\)表示出度

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;#define MAX 300inline int read(){ int x=0,t=1;char ch=getchar(); while((ch<'0'||ch>'9')&&ch!='-')ch=getchar(); if(ch=='-')t=-1,ch=getchar(); while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar(); return x*t;}struct Line{ int v,next;}e[MAX<<1];int lk[MAX];int h[MAX],cnt=1;int size[MAX],n,p,ans=1e9;inline void Add(int u,int v){ e[cnt]=(Line){v,h[u]}; h[u]=cnt++;lk[u]++;}int f[MAX][MAX];void DFS(int u,int ff){ size[u]=1;f[u][1]=lk[u]-(ff!=0); for(int i=h[u];i;i=e[i].next) { int v=e[i].v; if(v==ff)continue; DFS(v,u); for(int j=p;j;--j) for(int k=1;k<=j;++k) f[u][j]=min(f[u][j],f[v][k]+f[u][j-k]-1); } ans=min(ans,f[u][p]+(ff!=0));}int main(){ n=read();p=read(); for(int i=1;i

转载于:https://www.cnblogs.com/cjyyb/p/7806030.html

你可能感兴趣的文章
Python 之map、filter、reduce
查看>>
hdu1067
查看>>
2019年春季学期第四周作业
查看>>
公司web安全等级提升
查看>>
[BZOJ3224]普通平衡树(旋转treap,STL-vector)
查看>>
C++ - 派生类强制转换为基类
查看>>
存储过程优缺点
查看>>
【题解】[NOIP模拟题]我要的幸福-C++
查看>>
html5手势原理知识
查看>>
php中文转拼音的代码
查看>>
自我修复
查看>>
Leetcode: Path Sum
查看>>
#python#将函数赋值给变量时的一些问题
查看>>
服务器 未能加载文件或程序集“XXXX”或它的某一个依赖项。试图加载格式不正确的程序。...
查看>>
linux 网络设备,网卡配置 ,相关
查看>>
vue16 自定义键盘属性
查看>>
global-results
查看>>
CF870A Search for Pretty Integers
查看>>
分布式一致性算法--Paxos
查看>>
EFCodeFirst示例
查看>>