正解:二分+贪心

解题报告:

传送门$QwQ$

题目大意就说有一棵树,然后要用若干条线覆盖所有边且不能重叠.问最少要用几条线,在用线最少的前提下最长的线最短是多长.

昂首先最少用多少条线这个还是蛮$easy$的$QwQ$?显然答案就$1+\sum \frac{d_i-1}{2}$.考虑每个点的儿子都两两匹配,多出来的部分直接到父亲处做就成$QwQ$.加一是因为根节点本来不应该减一的因为没有父亲节点,所以就加回来$QwQ$.

然后看第二问.

首先显然先二分出一个长度.然后$check$就$dfs$,对每个点记录一个$dis_i$表示从这个点传来的链的长度.然后每$dfs$到一个点,先把它的子树处理完,将所有传上来的链按长度排序.

然后考虑分类讨论,对于有奇数个儿子的节点,就二分传上去的链的长度最小值是多少

然后对于有偶数个儿子的节点,如果可以一一匹配就直接一一匹配掉.否则考虑可以将最大值单独覆盖后当作奇数个儿子的节点做.昂因为这里我还理解了下才$get$的所以大概港下$QwQ$.

考虑每个点是有个向上传一条链的权限的,所以当有偶数个儿子节点时,就有一个让一条链落单匹配的权限,所以就可以把最长的那条链单独处理之后当作奇数儿子节点的做$QwQ$

$over$

#include<bits/stdc++.h>
using namespace std;
#define il inline
#define gc getchar()
#define t(i) edge[i].to
#define ri register int
#define rc register char
#define rb register bool
#define rp(i,x,y) for(ri i=x;i<=y;++i)
#define my(i,x,y) for(ri i=x;i>=y;--i)
#define e(i,x) for(ri i=head[x];i;i=edge[i].nxt) const int N=10000+10,inf=1e9+10;
int n,head[N],in[N],ed_cnt,as=1,mid,dis[N],stck[N],top;
bool flg,gdgs=1;
struct ed{int to,nxt;}edge[N<<1]; il int read()
{
rc ch=gc;ri x=0;rb y=1;
while(ch!='-' && (ch>'9' || ch<'0'))ch=gc;
if(ch=='-')ch=gc,y=0;
while(ch>='0' && ch<='9')x=(x<<1)+(x<<3)+(ch^'0'),ch=gc;
return y?x:-x;
}
il void ad(ri x,ri y){edge[++ed_cnt]=(ed){x,head[y]};head[y]=ed_cnt;++in[x];}
il bool jud(ri dat)
{ri l=1,r=top;while(gdgs){if(l==dat)++l;if(r==dat)--r;if(l>=r)return 1;if(stck[l]+stck[r]>mid)return 0;++l,--r;}}
void dfs(ri nw,ri fa)
{
if(!flg)return;
e(i,nw)if(t(i)^fa)dfs(t(i),nw);
top=0;e(i,nw)if(t(i)^fa)stck[++top]=dis[t(i)]+1;
sort(stck+1,stck+1+top);if(stck[top]>mid){flg=0;return;}
if(!(top&1)){rp(i,1,top/2)if(stck[i]+stck[top-i+1]>mid){if(nw==1){flg=0;return;}--top;break;}}
if(top&1)
{
ri l=1,r=top;if(!jud(top)){flg=0;return;}
while(l<r){ri md=(l+r)>>1;if(jud(md))r=md;else l=md+1;}
dis[nw]=stck[l];
}
}
il bool check(){memset(dis,0,sizeof(dis));flg=1;dfs(1,1);return flg;} int main()
{
freopen("2067.in","r",stdin);freopen("2067.out","w",stdout);
n=read();rp(i,1,n-1){ri x=read(),y=read();ad(x,y);ad(y,x);}rp(i,1,n)as+=(in[i]-1)/2;
ri l=1,r=n;while(l<r){mid=(l+r)>>1;if(check())r=mid;else l=mid+1;}printf("%d %d\n",as,l);
return 0;
}

随机推荐

  1. @codeforces - 1086F@ Forest Fires

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 一个无穷大的方格图,每个方格内都种了棵树. 一开始点燃了 n 棵 ...

  2. 亿级消息系统的核心存储:Tablestore发布Timeline 2.0模型

    背景 互联网快速发展的今天,社交类应用.消息类功能大行其道,占据了大量网络流量.大至钉钉.微信.微博.知乎,小至各类App的推送通知,消息类功能几乎成为所有应用的标配.根据场景特点,我们可以将消息类场 ...

  3. win10如何关闭计算机设备和驱动器非硬盘图标

    按win键+R,打开注册表regedit,找到这个路径: HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\My ...

  4. Android Animation动画实战(二):从屏幕底部弹出PopupWindow

    在这篇文章之前,我已经陆陆续续写了几篇博客,介绍了Android Animation是如何使用的,有还不明白的,可以点击查看: 1. Android Animation动画详解(一): 补间动画 2. ...

  5. SuperSocket特点

    ²  简单易用,只需要几个类就能创建出健壮的Socket服务器端程序 ²  性能优良, 稳定可靠 ²  支持各种协议, 内置的协议解析工具让你把实现通信协议这种复杂的工作变得很简单 ²  自动支持SS ...

  6. 9-6 UVa 11400

    参考 http://www.cnblogs.com/Kiraa/p/5510757.html http://www.cnblogs.com/zhaopAC/p/5159950.html 根据题目说明中 ...

  7. <STL源码剖析> 6.3.6 power

    计算power的算法说明 http://www.sxt.cn/u/324/blog/2112 翻译自  http://videlalvaro.github.io/2014/03/the-power-a ...

  8. 网易大数据平台的Spark技术实践

    网易大数据平台的Spark技术实践 作者 王健宗 网易的实时计算需求 对于大多数的大数据而言,实时性是其所应具备的重要属性,信息的到达和获取应满足实时性的要求,而信息的价值需在其到达那刻展现才能利益最 ...

  9. netstat 显示当前网络连接的统计信息

    C:\Users\Administrator\Desktop\hsqldb-2.3.2\data>netstat -h Displays protocol statistics and curr ...

  10. HTML5中Js多线程编程

    Web Worker Web Worker是HTML5提出的新标准,为 JavaScript 创造多线程环境,允许主线程创建 Worker 线程,将一些任务分配给后者运行.在主线程运行的同时,Work ...