题意

给定一棵 \(n\) 个点的树,给定 \(k\) ,求 \(|\frac{\sum w(路径长度)}{t(路径边数)}-k|\)的最小值。

\(n\leq 5\times 10^5,k\leq 10^{13}\)

分析

  • 看到分数考虑分数规划,二分答案 \(x\),式子转化成 \(-x< \frac{\sum w}{t}-k< x\)

  • 将边权变为 \(w-k\) 消除 \(k\) 的影响。但是不能够直接求最长链。因为是路径,考虑点分治。

  • 二分答案 \(x\) 之后考虑两条路径组合 \((A_1,B_1),(A_2,B_2)\),其中 \(A\) 表示路径长度,\(B\) 表示路径边数。
    有 \(-x<\frac{A_1+A_2}{B_1+B_2}< x\) ,当 \(A_1+A_2 > 0\) 时只用考虑 \(< x\) 的条件,得到 \(A_1-B_1x< B_2x-A_2\),反之同理。

  • 现在考虑 \(A_1+A_2 > 0\) 的情况。先将所有路径按照 \(A\) 排序后从左边开始枚举路径,然后用一个指针从右往左维护所有 \(A_1+A_2> 0\) 的路径,然后维护 \(Bx-A\) 的最小值。但是有可能最小值和当前枚举的路径相同,所以再记一个次小值。

  • 由于要下取整,先求出 \(> ans\) 的最小整数解然后 \(-1\) 。

  • 总时间复杂度为 \(O(nlog^2n)\)。

## 代码
~~~cpp
#include
using namespace std;
#define go(u) for(int i=head[u],v=e[i].to;i;i=e[i].lst,v=e[i].to)
#define rep(i,a,b) for(int i=a;iinline bool Max(T &a,T b){return ainline bool Min(T &a,T b){return b=0;--p)
upd(data(st[p].a-st[p].b*mid,0,st[p].from),m1,m2);
if(st[i].b*mid-st[i].a>(st[i].from==m1.from?m2.a:m1.a)) return 1;
}
return 0;
}
bool ck2(int u,LL mid){
int p=1;
data m1(inf,-1,-1),m2(inf,-1,-1);
for(int i=tp;i;--i){
for(;p(st[i].from==m1.from?m2.a:m1.a)) return 1;
}
return 0;
}
void dfs(int u){
vis[u]=1,st[tp=1]=data(0,0,0);
go(u)if(!vis[v]) {
d[v]=data(e[i].c,1,v);
getdep(v,u,v);
}
sort(st+1,st+1+tp);
LL l=1,r=ans;
while(l>1;
if(ck1(u,mid)||ck2(u,mid)) r=mid;
else l=mid+1;
}
Min(ans,l);

go(u)if(!vis[v])
rt=0,sn=son[v],getrt(v,u),dfs(rt);

}

int main(){

scanf("%d%lld",&n,&k);

rep(i,1,n-1){

int a,b;LL w;

scanf("%d%d%lld",&a,&b,&w);

Add(a,b,w-k);

Min(ans,abs(w-k)+1);

}

sn=n,g[rt=0]=0x3f3f3f3f,getrt(1,0),dfs(rt);

printf("%lld\n",ans-1);

return 0;

}

[UOJ#276][清华集训2016]汽水[分数规划+点分治]的更多相关文章

  1. [UOJ#274][清华集训2016]温暖会指引我们前行

    [UOJ#274][清华集训2016]温暖会指引我们前行 试题描述 寒冬又一次肆虐了北国大地 无情的北风穿透了人们御寒的衣物 可怜虫们在冬夜中发出无助的哀嚎 “冻死宝宝了!” 这时 远处的天边出现了一 ...

  2. BZOJ.4738.[清华集训2016]汽水(点分治 分数规划)

    BZOJ UOJ 记\(val_i\)是每条边的边权,\(s\)是边权和,\(t\)是经过边数,\(k\)是给定的\(k\). 在点分治的时候二分答案\(x\),设\(|\frac st-k|=x\) ...

  3. BZOJ 4732 UOJ #268 [清华集训2016]数据交互 (树链剖分、线段树)

    题目链接 (BZOJ) https://www.lydsy.com/JudgeOnline/problem.php?id=4732 (UOJ) http://uoj.ac/problem/268 题解 ...

  4. UOJ276 [清华集训2016] 汽水 【二分答案】【点分治】【树状数组】

    题目分析: 这种乱七八糟的题目一看就是点分治,答案有单调性,所以还可以二分答案. 我们每次二分的时候考虑答案会不会大于等于某个值,注意到系数$k$是无意义的,因为我们可以通过转化使得$k=0$. 合并 ...

  5. 并不对劲的uoj276. [清华集训2016]汽水

    想要很对劲的讲解,请点击这里 题目大意 有一棵\(n\)(\(n\leq 50000\))个节点的树,有边权 求一条路径使该路径的边权平均值最接近给出的一个数\(k\) 输出边权平均值下取整的整数部分 ...

  6. [UOJ#276]【清华集训2016】汽水

    [UOJ#276][清华集训2016]汽水 试题描述 牛牛来到了一个盛产汽水的国度旅行. 这个国度的地图上有 \(n\) 个城市,这些城市之间用 \(n−1\) 条道路连接,任意两个城市之间,都存在一 ...

  7. UOJ 275. 【清华集训2016】组合数问题

    UOJ 275. [清华集训2016]组合数问题 组合数 $C_n^m $表示的是从 \(n\) 个物品中选出 \(m\) 个物品的方案数.举个例子,从$ (1,2,3)(1,2,3)$ 三个物品中选 ...

  8. UOJ #269. 【清华集训2016】如何优雅地求和

    UOJ #269. [清华集训2016]如何优雅地求和 题目链接 给定一个\(m\)次多项式\(f(x)\)的\(m+1\)个点值:\(f(0)\)到\(f(m)\). 然后求: \[ Q(f,n,x ...

  9. UOJ #274. 【清华集训2016】温暖会指引我们前行 [lct]

    #274. [清华集训2016]温暖会指引我们前行 题意比较巧妙 裸lct维护最大生成树 #include <iostream> #include <cstdio> #incl ...

随机推荐

  1. 购物商城学习--第二讲(maven工程介绍)

    接下来第二讲介绍整体工程如何使用maven搭建的. 使用maven管理工程的好处: jar包的管理: 工程之间的依赖管理: 自动打包 maven常见打包方式:jar.war和pom三种.jar工程,是 ...

  2. 中式台球 规则 ( ChinaBilliards )

    中式台球比赛规则 中式台球兴起于上世纪八十年代末,之前叫法有“中式8球”.“中式9球”.“十六彩”.“美式落袋”.“普尔“.”八球””等等.中国台球协会于2012年宣布统一该项运动称呼,定名为“中式台 ...

  3. python基础学习12----装饰器

    装饰器可以在不修改目标函数代码的前提下, 在目标函数执行前后增加一些额外功能 例如有一个简单的函数 import time def func1(): print("这是一个简单的函数&quo ...

  4. python(set、dict)

    一.集合 它的元素是唯一的,并无序的. 1.集合定义 s = set() s = {1, 2, 3} 2.集合的方法 update版本的集合运算是在原集合上进行修改,返回值为None. add()表示 ...

  5. sed和awk学习整理

    Awk和Sed的基本使用 可以用大至相同的方式调用sed 和awk .命令行讲法是:command [options] script filename几乎和所有的unlx程序一样,sed和awk都可以 ...

  6. 028、HTML 标签1列表、图片、表格

    内容简单看一下理解就行了. HTML 是用来描述网页的一种语言.就是用来编写网页的语言 内容:换行.分割,标签属性,编码方式设置,字体标签,特殊符号,列表.图片.表格标签############### ...

  7. PyQt5--QProgressBar

    # -*- coding:utf-8 -*- ''' Created on Sep 20, 2018 @author: SaShuangYiBing Comment: ''' import sys f ...

  8. ubuntu 视频播放问题

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/chang_xing/article/details/30976659                ...

  9. CF838D Airplane Arrangements

    传送门:https://www.luogu.org/problemnew/show/CF838D 这道题反正我自己想是毫无头绪,最后还是听了肖大佬的做法. 因为题中说乘客可以从前后门进来,所以我们可以 ...

  10. javascript:void(0)的问题

    最近看了好几个关于<a>标签和javascript:void(0)的帖子,谨记于此,以资查阅. 注:以下代码未经全面测试,但每一种方法可能会出现的情况都基本做了说明. 在做页面时,如果想做 ...