【题意】

  给出一棵树。现在可以在树中删去m条边,使它变成m+1棵树。要求最小化树的直径的最大值。

【题解】

  二分答案。$Check$的时候用$DP$,记录当前节点每个儿子的直径$v[i]$,如果$v[i]+1>mid$,那么就断掉连向儿子的这条边。如果$v[i]+v[j]+2>mid$,那么在i与j中选择一个$v%值较大的断掉。

  

#include<cstdio>
#include<algorithm>
#define N 200010
#define rg register
using namespace std;
int n,m,tot,ans,cut,last[N],mid,f[N],a[N];
struct edge{int to,pre;
}e[N];
inline int read(){int k=0,f=1; char c=getchar();while(c<'0'||c>'9')c=='-'&&(f=-1),c=getchar();while('0'<=c&&c<='9')k=k*10+c-'0',c=getchar();return k*f;
}
inline void add(int x,int y){e[++tot]=(edge){y,last[x]};last[x]=tot;
}
void dfs(int x,int fa){f[x]=0;for(rg int i=last[x],to;i;i=e[i].pre)if((to=e[i].to)!=fa) dfs(to,x);int cnt=0;for(rg int i=last[x],to;i;i=e[i].pre)if((to=e[i].to)!=fa) a[++cnt]=f[to]+1;sort(a+1,a+cnt+1);while(a[cnt]+a[cnt-1]>mid) cut++,cnt--;f[x]=a[cnt];
}
bool check(){cut=0;dfs(1,0);//printf("mid=%d cut=%d\n",mid,cut);if(cut<=m) return 1;return 0;
}
int main(){n=read(); m=read();for(rg int i=1,u,v;i<n;i++){u=read(); v=read();add(u,v); add(v,u);}int l=0,r=n-1;while(l<r){mid=(l+r)>>1;if(check()) r=mid;else l=mid+1;}printf("%d\n",l);return 0;
}

  

转载于:https://www.cnblogs.com/DriverLao/p/8516340.html

BZOJ 2097 [Usaco2010 Dec]Exercise 奶牛健美操相关推荐

  1. BZOJ——T 2097: [Usaco2010 Dec]Exercise 奶牛健美操

    http://www.lydsy.com/JudgeOnline/problem.php?id=2097 Time Limit: 10 Sec  Memory Limit: 64 MB Submit: ...

  2. BZOJ 1827: [Usaco2010 Mar]gather 奶牛大集会 树形DP

    [Usaco2010 Mar]gather 奶牛大集会 Bessie正在计划一年一度的奶牛大集会,来自全国各地的奶牛将来参加这一次集会.当然,她会选择最方便的地点来举办这次集会.每个奶牛居住在 N(1 ...

  3. BZOJ 1827: [Usaco2010 Mar]gather 奶牛大集会 树形DP + 带权重心

    Description Bessie正在计划一年一度的奶牛大集会,来自全国各地的奶牛将来参加这一次集会.当然,她会选择最方便的地点来举办这次集会.每个奶牛居住在 N(1<=N<=100,0 ...

  4. BZOJ 1779. [Usaco2010 Hol]Cowwar 奶牛战争

    传送门 考虑构建网络流模型 把一个流量看成一只奶牛的攻击过程,那么答案就是最大流 因为每只奶牛只能操作一波,所以构造分层图,一层相当于一步 第一层就是初始状态,从 $S$ 向所有 $J$ 奶牛连一条流 ...

  5. bzoj 1827: [Usaco2010 Mar]gather 奶牛大集会【树形dp】

    不能用read会TLE!!不能用read会TLE!!不能用read会TLE!! 一开始以为要维护每个点,线段树写了好长(还T了-- 首先dfs一遍,求出点1为集会地点的答案,处理处val[u]为以1为 ...

  6. [Usaco2010 Mar]gather 奶牛大集会

    1827: [Usaco2010 Mar]gather 奶牛大集会 Time Limit: 1 Sec  Memory Limit: 64 MB Submit: 1129  Solved: 525 [ ...

  7. bzoj2101【Usaco2010 Dec】Treasure Chest 藏宝箱

    2101: [Usaco2010 Dec]Treasure Chest 藏宝箱 Time Limit: 10 Sec  Memory Limit: 64 MB Submit: 418  Solved: ...

  8. bzoj 1648: [Usaco2006 Dec]Cow Picnic 奶牛野餐(暴力DFS)

    1648: [Usaco2006 Dec]Cow Picnic 奶牛野餐 Time Limit: 5 Sec  Memory Limit: 64 MB Submit: 774  Solved: 480 ...

  9. bzoj 1690: [Usaco2007 Dec]奶牛的旅行(01分数规划--最优比率环)

    01分数规划问题: 给你n个物品,a[i]表示第i个物品的收益,b[i]表示代价,x[i]表示选或不选,求一个最佳方案使得下式取值最大 通用解: 当然是从式子上考虑,定义函数F[cnt]如下: 其中c ...

最新文章

  1. LeetCode 221. Maximal Square----动态规划--谷歌面试算法题--Python解法
  2. SAP S4HANA MRP LIVE
  3. php 语法 条件变量,C ++核心准则:注意条件变量的陷阱
  4. opengl 大作业_「陪玩时光」糕妈:说说年糕的小学生活,先从陪作业和家长群聊起...
  5. 全球酒店详情查看API接口-基于极核数据
  6. 界面按钮太多 聊天机器人都快被玩坏了
  7. load styles.php,wordpress后台管理超时没反应:load-scripts.php载入缓慢出错
  8. Java 正则表达式匹配模式[贪婪型、勉强型、占有型]
  9. 前端解决跨域问题的8种方案
  10. 读书笔记8-浪潮之巅(part3)
  11. linux ntp连接失败,linux ntp服务器连接异常
  12. C++ AFX_MANAGE_STATE(AfxGetStaticModuleState())的作用
  13. 编程体系结构(03):Java集合容器
  14. php mysql select where_PHP MySQL Where 子句
  15. mac电脑如何查看ip地址
  16. 影视】100种说爱你的方式~
  17. ubuntu 版mysql客户端工具_几款桌面MYSQL管理工具
  18. 计算机组成原理图ei,(完整版)计算机组成原理试题库(含答案)-
  19. openresty ngx_lua日志操作
  20. 计算机怎么截音乐,电脑怎么剪辑音乐 怎样在电脑上剪辑歌曲

热门文章

  1. 选择排序与冒泡排序的区别
  2. java多线程区别_Java中实现多线程的两种方式之间的区别
  3. 不能将紧实的字段 绑定到_代码整洁之道【笔记】
  4. android 撑满剩余空间,怎么让LinearLayout占据父布局的所有剩余空间
  5. 网站开发用什么语言好_网站开发教程:企业如何用网站开启在线业务?
  6. python中字符编码使用_python中字符编码是什么?如何转换字符?
  7. RS-232/E1协议转换器产品介绍
  8. 什么叫光端机?视频光端机的分类具体有哪些?
  9. POE供电交换机技术分析及工作过程详解
  10. 工业交换机外壳选用时有什么要求?