洛谷传送门
【题目分析】
感叹自己当年为何连二分都能打挂。。。
首先最短路径最长,很容易想到二分,关键就是check的写法。
正解是有点神仙的贪心,用dp[u]表示u的子树内未被选择的最大路径的长度,对于子节点v,如果满足dp[v]+w[u,v]>=mid cnt就加1,否则压入multiset中作为待选择路径。
将未选择的路径排序,然后就是lowerbound找mid-len即可。
代码常数有点点大,开个O2还看得过去
#include<bits/stdc++.h>
using namespace std;
const int MAXN=5e4+10;
const int MAXM=1e5+10;
int n,m,cnt;
int head[MAXN],dp[MAXN];
int nxt[MAXM],to[MAXM],w[MAXM];
int sta[MAXN],top;
multiset<int> s;
int l,r,mid,ans;
int Read(){
int i=0,f=1;
char c=getchar();
for(;(c>'9'||c<'0')&&c!='-';c=getchar());
if(c=='-&#