http://cogs.pro:8080/cogs/problem/problem.php?pid=vSXNiVegV

题意:给个树,第i个点有两个权值ai和bi,现在求一条长度为m的路径,使得Σai/Σbi最小。

思路:二分答案得p,把每个点权值变成ai-p*bi,看是否存在长为一条长为m的路使总和<=0。

tag数组表示从当前位置沿最长链走到底的值,dp数组初值表示从当前位置的重儿子走到底的值(加负号),用tag[...]+dp[..]维护从当前节点往下走若干步得到的最小值(只更新dp数组

 # include <stdio.h>
# include <string.h>
# include <iostream>
# include <algorithm>
// # include <bits/stdc++.h> using namespace std; typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
const int N = 3e4 + , M = 6e4 + ;
const int mod = 1e9+; int n, m, A[N * ], B[N * ], head[N], nxt[M], to[M], tot = ;
inline void add(int u, int v) {
++tot; nxt[tot] = head[u]; head[u] = tot; to[tot] = v;
}
inline void adde(int u, int v) {
add(u, v), add(v, u);
} int dep[N], mxd[N], son[N], sz[N];
inline void pre_dfs(int x, int fa = ) {
dep[x] = dep[fa] + ;
mxd[x] = dep[x]; son[x] = ;
for (int i=head[x]; i; i=nxt[i]) {
if(to[i] == fa) continue;
pre_dfs(to[i], x);
if(mxd[to[i]] > mxd[x]) mxd[x] = mxd[to[i]], son[x] = to[i];
}
sz[x] = mxd[x] - dep[x];
} int pos[N], idx;
inline void pre_pos(int x, int fa = ) {
pos[x] = ++idx;
if(son[x]) pre_pos(son[x], x);
for (int i=head[x]; i; i=nxt[i])
if(to[i] != fa && to[i] != son[x]) pre_pos(to[i], x);
} double mid_check, ans;
double dp[N], tag[N];
inline void solve(int x, int fa = ) {
double *f = &dp[pos[x]], C = (double)A[x] - mid_check * B[x];
if(son[x] == ) { //leaf
f[] = ; tag[x] = C;
if(m == ) ans = min(ans, tag[x]);
return ;
}
solve(son[x], x); f[] = -tag[son[x]];
tag[x] = tag[son[x]] + C;
for (int i=head[x], y; i; i=nxt[i]) {
if(to[i] == fa || to[i] == son[x]) continue;
solve(y = to[i], x);
double *g = &dp[pos[y]];
for (int j=; j<=sz[y] && j<m; ++j)
if(m--j <= sz[x]) ans = min(ans, f[m--j] + tag[x] + g[j] + tag[y]);
for (int j=; j<=sz[y]; ++j) f[j+] = min(f[j+], g[j] + tag[y] + C - tag[x]);
}
if(m <= sz[x]) ans = min(ans, f[m] + tag[x]);
} inline bool chk(double x) {
ans = 1e18; mid_check = x;
solve();
return ans <= ;
} int main() {
freopen("cdcq_b.in", "r", stdin);
freopen("cdcq_b.out", "w", stdout);
cin >> n >> m;
for (int i=; i<=n; ++i) scanf("%d", A+i);
for (int i=; i<=n; ++i) scanf("%d", B+i);
if(m == -) {
double ans = 1e18;
for (int i=; i<=n; ++i) ans = min(ans, (double)A[i]/B[i]);
printf("%.2lf\n", ans);
return ;
}
for (int i=, u, v; i<n; ++i) {
scanf("%d%d", &u, &v);
adde(u, v);
}
--m;
pre_dfs();
pre_pos();
double l = , r = 1e11, mid;
while(r-l > 1e-) {
mid = (l+r)/2.0;
if(chk(mid)) r = mid;
else l = mid;
}
if(l > 5e10) puts("-1");
else printf("%.2lf\n", l);
return ;
}

cogs 2652. 秘术「天文密葬法」(0/1分数规划 长链剖分 二分答案 dp的更多相关文章

  1. 【COGS2652】秘术「天文密葬法」(长链剖分,分数规划)

    [COGS2652]秘术「天文密葬法」(长链剖分,分数规划) 题面 Cogs 上面废话真多,建议直接拉到最下面看一句话题意吧: 给个树,第i个点有两个权值ai和bi,现在求一条长度为m的路径,使得Σa ...

  2. [COGS2652]秘术「天文密葬法」

    description 题面 给个树,第\(i\)个点有两个权值\(a_i\)和\(b_i\),现在求一条长度为\(m\)的路径,使得\(\frac{\sum a_i}{\sum b_i}\)最小 d ...

  3. 【LOJ】#3014. 「JOI 2019 Final」独特的城市(长链剖分)

    LOJ#3014. 「JOI 2019 Final」独特的城市(长链剖分) 显然我们画一条直径,容易发现被统计的只可能是直径某个距离较远的端点到这个点的路径上的值 用一个栈统计可以被统计的点,然后我们 ...

  4. 2019.03.11 COGS2652 秘术(天文密葬法)(分数规划+长链剖分)

    传送门 题意:nnn个点的树,每个点两个值a,ba,ba,b,问长度为mmm的路径∑ai∑bi\frac{\sum a_i}{\sum b_i}∑bi​∑ai​​的最大值. 思路:一眼要01分数规划, ...

  5. 「vijos」lxhgww的奇思妙想(长链剖分)

    传送门 长链剖分的板子(又是乱搞优化暴力) 对于每一个点,我们定义它深度最深的子节点为它的重儿子(为什么不叫长儿子……),他们之间的连边为重边 然后长链剖分有几个性质 1.总链长为$O(n)$ 2.一 ...

  6. P7581-「RdOI R2」路径权值【长链剖分,dp】

    正题 题目链接:https://www.luogu.com.cn/problem/P7581 题目大意 给出\(n\)个点的有边权有根树,\(m\)次询问一个节点\(x\)的所有\(k\)级儿子两两之 ...

  7. 「WC2010」重建计划(长链剖分/点分治)

    「WC2010」重建计划(长链剖分/点分治) 题目描述 有一棵大小为 \(n\) 的树,给定 \(L, R\) ,要求找到一条长度在 \([L, R]\) 的路径,并且路径上边权的平均值最大 \(1 ...

  8. LOJ 3089 「BJOI2019」奥术神杖——AC自动机DP+0/1分数规划

    题目:https://loj.ac/problem/3089 没想到把根号之类的求对数变成算数平均值.写了个只能得15分的暴力. #include<cstdio> #include< ...

  9. 「NOI2015」「Codevs4621」软件包管理器(树链剖分

    4621 [NOI2015]软件包管理器 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond   题目描述 Description Linux用户和OSX用户一定对 ...

随机推荐

  1. JavaSE之——并没有多维数组

     近日在读<疯狂Java讲义>精粹第二版,部分语述摘自其中,自己边敲边理解 前言       我们知道,Java语言支持的类型有两种:            1.基本类型(即八大基本数据类 ...

  2. 使用Junit测试一个 spring静态工厂实例化bean 的例子,所有代码都没有问题,但是出现java.lang.IllegalArgumentException异常

    使用Junit测试一个spring静态工厂实例化bean的例子,所有代码都没有问题,但是出现 java.lang.IllegalArgumentException 异常, 如下图所示: 开始以为是代码 ...

  3. luogu1373_小a和uim之大逃离 多维dp

    传送门 巧妙之处在于dp的设计只用设计差值即可,因此不会mle,枚举的顺序问题也解决了 #include <bits/stdc++.h> using namespace std; #def ...

  4. mysql docker 主从配置

    主从复制相关 前置条件: docker安装的mysql是5.7.26版本 1. 编排docker-compose文件如下: version: '3' services: mysql-master: v ...

  5. alluxio源码解析-netty部分(2)

    netty简介 Netty是 一个异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端.   netty作为alluxio中重要的通讯组件 在常见的客户端上传,下载中,都会有n ...

  6. SVN服务器更改ip地址客户端怎么设置

    SVN 服务器 IP 地址修改后,客户端对服务器的连接可以采用以下的方法重定位: 1. 如果客户端工具是TortoiseSVN,直接在工作副本上右键,选择TortoiseSVN->relocat ...

  7. 使用mybatis实现分页查询示例代码分析

    *******************************************分页查询开始*************************************************** ...

  8. intellIJ IDEA学习笔记3

    intellij idea 的快捷鍵 https://blog.csdn.net/wei83523408/article/details/60472168 https://www.cnblogs.co ...

  9. AOSP 预置 APP

    Android 系统预置 APP 是做 Framework 应用开发经常经常会遇到的工作,预置 APP 分为两种,一种是直接预置 APK,一种是预置带有源码的 APP. 预置 apk 示例说明 以 . ...

  10. c#自定义控件中的事件处理

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Drawing; u ...