链接

https://www.luogu.org/problemnew/show/P4069

思路

树剖+超哥线段树

我已经自毙了,自闭了!!!!

update

上次抄了没认真看,这次考试又自毙了

是一个细节的处理上一次没处理

代码

#include <bits/stdc++.h>
#define ll long long
#define ls rt<<1
#define rs rt<<1|1
using namespace std;
const ll inf=123456789123456789LL;
const ll N=5e5+7;
ll read() {
ll x=0,f=1;char s=getchar();
for(;s>'9'||s<'0';s=getchar()) if(s=='-') f=-1;
for(;s>='0'&&s<='9';s=getchar()) x=x*10+s-'0';
return x*f;
}
ll n,m;
struct edge {
ll v,nxt,q;
}e[N<<1];
ll head[N<<1],tot;
void add(ll u,ll v,ll q) {
e[++tot].v=v;
e[tot].q=q;
e[tot].nxt=head[u];
head[u]=tot;
}
ll fa[N],dep[N],son[N],siz[N];
ll dis[N];
void dfs1(ll u,ll f) {
dep[u]=dep[f]+1;
siz[u]=1;
fa[u]=f;
for(ll i=head[u];i;i=e[i].nxt) {
ll v=e[i].v;
if(v==f) continue;
dis[v]=dis[u]+(ll)e[i].q;
dfs1(v,u);
siz[u]+=siz[v];
if(siz[son[u]]<siz[v]) son[u]=v;
}
}
ll idx[N],top[N],js;
ll xxx[N];
void dfs2(ll u,ll topf) {
idx[u]=++js;
xxx[js]=u;
top[u]=topf;
if(!son[u]) return;
dfs2(son[u],topf);
for(ll i=head[u];i;i=e[i].nxt) {
ll v=e[i].v;
if(!idx[v]) dfs2(v,v);
}
}
struct node {
ll l,r;
ll a,b,mi;
}tr[N<<2];
void build(ll l,ll r,ll rt) {
tr[rt].l=l,tr[rt].r=r;
tr[rt].mi=tr[rt].b=inf;
if(l==r) return;
ll mid=(l+r)>>1;
build(l,mid,ls);
build(mid+1,r,rs);
}
ll f(ll a,ll b,ll x) {
return a*dis[xxx[x]]+b;
}
#define f_l f(tr[rt].a,tr[rt].b,tr[rt].l)
#define f_r f(tr[rt].a,tr[rt].b,tr[rt].r)
void pushup(ll rt) {
tr[rt].mi=min(tr[rt].mi,min(tr[ls].mi,tr[rs].mi));
tr[rt].mi=min(tr[rt].mi,min(f_l,f_r));
}
void modify(ll L,ll R,ll a,ll b,ll rt) {
if(L<=tr[rt].l&&tr[rt].r<=R) {
if(f_l<=f(a,b,tr[rt].l)&&f_r<=f(a,b,tr[rt].r)) return;
if(f_l>f(a,b,tr[rt].l)&&f_r>f(a,b,tr[rt].r)) {
tr[rt].a=a;
tr[rt].b=b;
tr[rt].mi=min(tr[rt].mi,min(f_l,f_r));
return;
}
ll mid=(tr[rt].l+tr[rt].r)>>1; if(tr[rt].a<=a) {
if(f(tr[rt].a,tr[rt].b,mid)>=f(a,b,mid)) {
swap(tr[rt].a,a);
swap(tr[rt].b,b);
modify(L,R,a,b,rs);
} else modify(L,R,a,b,ls);
} else {
if(f(tr[rt].a,tr[rt].b,mid)>=f(a,b,mid)) {
swap(tr[rt].a,a);
swap(tr[rt].b,b);
modify(L,R,a,b,ls);
} else modify(L,R,a,b,rs);
}
tr[rt].mi= min(min(tr[ls].mi, tr[rs].mi), min(f_l,f_r));
// pushup(rt);
return;
}
ll mid=(tr[rt].l+tr[rt].r)>>1;
if(L<=mid) modify(L,R,a,b,ls);
if(R>mid) modify(L,R,a,b,rs);
pushup(rt);
} ll query(ll L,ll R,ll rt) {
if(L<=tr[rt].l&&tr[rt].r<=R) {
return tr[rt].mi;
}
ll mid=(tr[rt].l+tr[rt].r)>>1;
ll ans=inf;
ans=min(ans,min(f(tr[rt].a,tr[rt].b,max(L,tr[rt].l)),f(tr[rt].a,tr[rt].b,min(tr[rt].r,R))));
if(L<=mid) ans=min(ans,query(L,R,ls));
if(R>mid) ans=min(ans,query(L,R,rs));
return ans;
}
ll lca(ll x,ll y) {
while(top[x]!=top[y]) {
if(dep[top[x]] < dep[top[y]]) swap(x,y);
x=fa[top[x]];
}
if(dep[x]>dep[y]) swap(x,y);
return x;
}
void C(ll x,ll y,ll a,ll b) {
while(top[x]!=top[y]) {
if(dep[top[x]] < dep[top[y]]) swap(x,y);
modify(idx[top[x]],idx[x],a,b,1);
x=fa[top[x]];
}
if(dep[x]>dep[y]) swap(x,y);
modify(idx[x],idx[y],a,b,1);
}
void Q(ll x,ll y) {
ll ans=inf;
while(top[x]!=top[y]) {
if(dep[top[x]] < dep[top[y]]) swap(x,y);
ans=min(ans,query(idx[top[x]],idx[x],1));
x=fa[top[x]];
}
if(dep[x]>dep[y]) swap(x,y);
ans=min(ans,query(idx[x],idx[y],1));
printf("%lld\n",ans);
}
int main() {
n=read(),m=read();
for(ll i=1;i<n;++i) {
ll x=read(),y=read(),z=read();
add(x,y,z);
add(y,x,z);
}
dfs1(1,0);
dfs2(1,1);
build(1,n,1);
while(m--) {
ll opt=read();
if(opt==1) {
ll s=read(),t=read();
ll A=read(),B=read();
ll dsr=lca(s,t);
C(s,dsr,(ll)-A,1LL*dis[s]*A+B);
C(dsr,t,(ll)A,1LL*dis[s]*A-2LL*A*dis[dsr]+B);
} else {
ll s=read(),t=read();
Q(s,t);
}
}
return 0;
}

[SDOI2016]游戏 树剖+李超树的更多相关文章

  1. [SDOI2016]游戏(树剖+李超树)

    趁着我把李超树忘个一干二净的时候来复习一下吧,毕竟马上NOI了. 题解:看着那个dis就很不爽,直接把它转换成深度问题,然后一条直线x->y,假设其lca为z,可以拆分成x->z和z-&g ...

  2. BZOJ_2238_Mst_树剖+线段树

    BZOJ_2238_Mst_树剖+线段树 Description 给出一个N个点M条边的无向带权图,以及Q个询问,每次询问在图中删掉一条边后图的最小生成树.(各询问间独立,每次询问不对之后的询问产生影 ...

  3. BZOJ_2588_Spoj 10628. Count on a tree_树剖+主席树

    BZOJ_2588_Spoj 10628. Count on a tree_树剖+主席树 题意: 给定一棵N个节点的树,每个点有一个权值,对于M个询问(u,v,k),你需要回答u xor lastan ...

  4. BZOJ_4551_[Tjoi2016&Heoi2016]树_树剖+线段树

    BZOJ_4551_[Tjoi2016&Heoi2016]树_树剖+线段树 Description 在2016年,佳媛姐姐刚刚学习了树,非常开心.现在他想解决这样一个问题:给定一颗有根树(根为 ...

  5. BZOJ_2157_旅游_树剖+线段树

    BZOJ_2157_旅游_树剖+线段树 Description Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但 ...

  6. 【BZOJ5210】最大连通子块和 树剖线段树+动态DP

    [BZOJ5210]最大连通子块和 Description 给出一棵n个点.以1为根的有根树,点有点权.要求支持如下两种操作: M x y:将点x的点权改为y: Q x:求以x为根的子树的最大连通子块 ...

  7. [LNOI2014]LCA(树剖+线段树)

    \(\%\%\% Fading\) 此题是他第一道黑题(我的第一道黑题是蒲公英) 一直不敢开,后来发现是差分一下,将询问离线,树剖+线段树维护即可 \(Code\ Below:\) #include ...

  8. [CF1007D]Ants[2-SAT+树剖+线段树优化建图]

    题意 我们用路径 \((u, v)\) 表示一棵树上从结点 \(u\) 到结点 \(v\) 的最短路径. 给定一棵由 \(n\) 个结点构成的树.你需要用 \(m\) 种不同的颜色为这棵树的树边染色, ...

  9. 2018.08.30 NOIP模拟 graph(dfs序/树剖+线段树)

    [描述] 给你一个图,一共有 N 个点,2*N-2 条有向边. 边目录按两部分给出 1. 开始的 n-1 条边描述了一颗以 1 号点为根的生成树,即每个点都可以由 1 号点 到达. 2. 接下来的 N ...

随机推荐

  1. Unity shader学习之逐像素漫反射光照模型

    shader如下: Shader "Custom/Diffuse Fragment-Level" { Properties { _Diffuse (,,,) } SubShader ...

  2. Python全栈-day11-函数3

    装饰器 1.开放封闭原则 通常情况下,软件一旦上线就应该遵循开放封闭原则,即对修改封闭.对扩展开放 扩展开放需遵循两个原则: 1)不修改源代码 2)不修改原函数的调用方式 2.装饰器 器指的是工具,装 ...

  3. STL之Deque容器

    1.Deque容器 1)deque是“double-ended queue”的缩写,和vector一样都是STL的容器,deque是双端数组,而vector是单端的. 2)deque在接口上和vect ...

  4. 【2017-2-23】C#switch case分支语句,for循环语句

    switch case分支语句 switch(一个变量值) { case 值:要执行的代码段;break; case 值:要执行的代码段;break; … default:代码段;break;(def ...

  5. kalinux实现自适用全屏、与物理主机共享文件方法

    1.执行虚拟机>安装VMware Tools菜单命令,自动挂载光驱(一般是自动挂载的,如果没有自动挂载请自行百度linux如何手动挂载光驱) 2.打开vm光驱的vmtools复制此文件到桌面: ...

  6. git使用遇到的坑

    把一个完整项目提交到github上步骤以及注意事项 Git的安装就不说了. 第一步:mkdir/cd 我们需要先创建一个本地的版本库(其实也就是一个文件夹). 你可以直接右击新建文件夹,也可以右击打开 ...

  7. 转:【专题九】实现类似QQ的即时通信程序

    引言: 前面专题中介绍了UDP.TCP和P2P编程,并且通过一些小的示例来让大家更好的理解它们的工作原理以及怎样.Net类库去实现它们的.为了让大家更好的理解我们平常中常见的软件QQ的工作原理,所以在 ...

  8. Step7:SQL Server 多实例下的复制

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 搭建步骤(Procedure) 注意事项(Attention) 二.背景(Contexts) ...

  9. Linux下MySQL远程链接配置

    配置步骤: 1).首先进入数据库,使用系统数据库mysql mysql -u root -p mysql 2).接着对系统数据库的root账户设置远程访问的密码,与本地的root访问密码并不冲突 gr ...

  10. 可视化的fineBI很高大上 使用简单,简单操作了一下,拖一拖就行,收费 只能看一下人家的demo 网站 http://demo.finebi.com/webroot/decision#directory