[Bzoj1767][Ceoi2009]harbingers (树上斜率优化)
1767: [Ceoi2009]harbingers
Time Limit: 10 Sec Memory Limit: 64 MB
Submit: 451 Solved: 120
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
Sample Output
HINT
分析:
考虑暴力
其中j为i的祖先。
发现很显然的斜率优化式子模型,转化成点斜式
发现x是单增的,可以使用单调栈维护下凸包,答案就是使截矩b最小的点对(x,y)
但发现斜率k是不单调的,代表决策不单调,所以只有采用二分寻找最优决策。
这还是很显然的,但是这道题是在树上,树上根节点到当前点的凸包要在它每个儿子都会使用到,要想办法维护根节点到每个点的凸包。
我们加入一个点后,不从队首开始pop,而是二分寻找它该加入的位置,把那个位置改成当前点,并记录下原来的点和位置。
处理它的所有儿子结点后,又把当前点改回原来的点。这样就做到保存各点凸包信息了。
坑点:会炸long long 比较斜率的时候被迫使用double。
AC代码:
- # include <iostream>
- # include <cstdio>
- # include <cstring>
- using namespace std;
- const int N = 3e5 + ;
- typedef long long LL;
- int n,dt,head[N],que[N];LL f[N],d[N],v[N],w[N];
- struct Edge{
- int to,nex;LL w;
- }edge[N << ];
- void AddEdge(int u,int v,LL w)
- {
- edge[++dt] = (Edge){v,head[u],w};
- head[u] = dt;
- }
- LL x(int i){return d[i];}
- LL y(int i){return f[i];}
- LL Get(int A,int B){return f[A] + (d[B] - d[A]) * v[B] + w[B];}
- double slope(int A,int B){return ((double)(y(B) - y(A))) / ((double)(x(B) - x(A)));}
- bool Cross(int A,int B,int C){return slope(B,C) <= slope(A,B);}
- int find(int x,int tp)
- {
- int l = ,r = tp,ret = ,mid;
- while(l <= r)
- {
- mid = l + r >> ;
- if(Get(que[mid],x) < Get(que[mid - ],x))ret = mid,l = mid + ;
- else r = mid - ;
- }
- return ret;
- }
- int Find(int z,int tp)
- {
- int l = ,r = tp,ret = tp + ,mid;
- while(l <= r)
- {
- mid = l + r >> ;
- if(Cross(que[mid - ],que[mid],z))ret = mid,r = mid - ;
- else l = mid + ;
- }
- return ret;
- }
- void dfs(int u,int pos,int fa)
- {
- int qpos,qtop;
- f[u] = Get(que[find(u,pos)],u);
- qpos = Find(u,pos);qtop = que[qpos];
- que[qpos] = u;
- for(int i = head[u];i;i = edge[i].nex)
- {
- if(edge[i].to == fa)continue;
- d[edge[i].to] = d[u] + edge[i].w;
- dfs(edge[i].to,qpos,u);
- }
- que[qpos] = qtop;
- }
- int main(){
- scanf("%d",&n);
- int x,y,z;
- for(int i = ;i < n;i++)
- {
- scanf("%d %d %d",&x,&y,&z);
- AddEdge(x,y,z);AddEdge(y,x,z);
- }
- for(int i = ;i <= n;i++)scanf("%lld %lld",&w[i],&v[i]);
- dfs(,,);printf("%lld",f[]);
- for(int i = ;i <= n;i++)printf(" %lld",f[i]);
- }
[Bzoj1767][Ceoi2009]harbingers (树上斜率优化)的更多相关文章
- [NOI2014]购票 「树上斜率优化」
首先易得方程,且经过变换有 $$\begin{aligned} f_i &= \min\limits_{dist_i - lim_i \le dist_j} \{f_j + (dist_i - ...
- [洛谷U22158]策划体验(树上斜率优化)(二分最优决策)
题目背景 OL不在,Clao又在肝少*前线,他虽然觉得这个游戏的地图很烦,但是他认为地图的难度还是太低了,习习中作为策划还不够FM,于是他自己YY了一种新的地图和新的机制: 题目描述 整个地图呈树形结 ...
- bzoj1767[Ceoi2009]harbingers 斜率优化dp
1767: [Ceoi2009]harbingers Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 421 Solved: 112[Submit][S ...
- HDU - 59562016ACM/ICPC亚洲区沈阳站I - The Elder 树上斜率优化dp
题意:给定上一棵树,然后每条边有一个权值,然后每个点到 1 的距离有两种,第一种是直接回到1,花费是 dist(1, i)^2,还有另一种是先到另一个点 j,然后两从 j 向1走,当然 j 也可以再向 ...
- BZOJ1767 : [Ceoi2009]harbingers
设d[i]表示i到1的距离 f[i]=w[i]+min(f[j]+(d[i]-d[j])*v[i])=w[i]+d[i]*v[i]+min(-d[j]*v[i]+f[j]) 对这棵树进行点分治,每次递 ...
- 【BZOJ-3672】购票 树分治 + 斜率优化DP
3672: [Noi2014]购票 Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 1177 Solved: 562[Submit][Status][ ...
- 洛谷 P3994 高速公路(斜率优化)
题目链接 题意:给出一棵树,\(1\) 号点为根,边上有边权. 每个点有两个参数 \(p_i,q_i\) 如果你想从 \(i\) 号点到与其距离为 \(d\) 的 \(j\) 号点,那么你需花费 \( ...
- BZOJ1767/Gym207383I CEOI2009 Harbingers 斜率优化、可持久化单调栈、二分
传送门--BZOJCH 传送门--VJ 注:本题在BZOJ上是权限题,在Gym里面也不能直接看,所以只能在VJ上交了-- 不难考虑到这是一个\(dp\). 设\(dep_x\)表示\(x\)在树上的带 ...
- BZOJ 1767] [Ceoi2009] harbingers (斜率优化)
[BZOJ 1767] [Ceoi2009] harbingers (斜率优化) 题面 给定一颗树,树中每个结点有一个邮递员,每个邮递员要沿着唯一的路径走向capital(1号结点),每到一个城市他可 ...
随机推荐
- qt project settings被禁用解决方案
转载请注明出处:http://www.cnblogs.com/dachen408/p/7422707.html qt project settings被禁用点击不了: 解决方案:需要点击该项目(或者项 ...
- Cognos添加维度
1.打开后台cognos中的报表,创建查询主题 填写该维度的名称 以时间维度为例 从左边添加该维度的单位,修改名称(在Cognos前台显示),如果有逻辑在源里面修改下函数 以此类推.
- 最新精品 强势来袭 XP,32/64位Win7,32/64位Win8,32/64位Win10系统【国庆版版】
本系统是10月最新完整版本的Windows10 安装版镜像,Win10正式版,更新了重要补丁,提升应用加载速度,微软和百度今天宣布达成合作,百度成为Win10 Edge浏览器中国默认主页和搜索引擎,系 ...
- 洛谷 P2866 [USACO06NOV]糟糕的一天Bad Hair Day
题目描述 Some of Farmer John's N cows (1 ≤ N ≤ 80,000) are having a bad hair day! Since each cow is self ...
- 【整理】treeGrid 树形表格
treeGrid 树形表格 https://fly.layui.com/extend/treeGrid/
- render_to_response()
render_to_response('模板名称',字典) 字典:第二个参数必须是为该模板创建context时所使用的字典,如果不提供第二个参数,render_response()使用一个空字典
- C++ 类中的static成员的初始化和特点
C++ 类中的static成员的初始化和特点 #include <iostream> using namespace std; class Test { public: Test() : ...
- 硬盘写入 iso
https://www.jb51.net/softjc/508796.html WinImage 正确操作是要有两个or以上-硬盘. 这样才能写入你要装的操作系统 测试或者安装
- MySQL redo log 与 binlog 的区别
MySQL redo log 与 binlog 的区别 什么是redo log 什么是binlog redo log与binlog的区别 1. 什么是redo log? redo log又称重做日志文 ...
- js layui 分页脚本
//分页 layui.use(['laypage'], function(){ var laypage = layui.laypage; laypage.render({ elem: 'page' , ...