【LuoguP3241】[HNOI2015] 开店

题目链接

题意

给出一棵边带权的树,多次在线询问一个点到一个区间内的点的距离和。

Sol

分块过不了的

一个 trick ,都知道要算两点之间距离可以拆成到根的距离和他们的 LCA 到根的距离 ,其实要算多个点到一个点距离也可以使用一个类似的 trick。
问题就在于快速求解所有的:\[\sum_{v\in S}deep[LCA(u,v)]\]
我们对于要询问的点集 \(S\) ,每一个点向上把所有反祖的边都覆盖一次,然后对于 \(u\) 点我们把它拿着一步步向上走,对于每一条经过的边把它被覆盖的次数与这条边的边权的积求和,最后就是上面那个式子了。

也就是说现在我们的问题是快速求出一个区间内所有点向上覆盖后某一个点向上的每条边被覆盖的次数与边权的积。
这个显然就用 主席树+树链剖分 来维护一下就可以了。
把点按顺序插入,每一个点在树上用树剖往上,每一段在内层线段树中进行修改。
不过这里是区间修改,直接打可下放标记可能会很伤空间 ,那么可以用标记永久化。

但是我们这里是区间询问,那么就要用到一些巧妙的方法。
这个方法也可以用于二维线段树等一般只适用于单点查询的问题。
观察我们的询问方式,先把我们要询问的区间分为 \(log\) 个区间,然后当当前区间被完全覆盖的时候我们为了保证复杂度肯定不能继续往下了,这样如果我们使用常规的标记永久化的话我们就有可能没办法计算到下面的点的答案了。
这样子我们就还需要维护一个标记,表示当前区间总修改量,即使当前区间没有被修改完全修改我们也要更新这个标记。
这样当我们查询到一个被询问区间完全覆盖的区间的时候我们就直接把当前区间的总修改量加上就可以了,因为我们只有当询问完全覆盖当前区间的时候才会用到这个标记,而这个标记相当于是把下面的修改信息都上传了之后的信息,就没有问题了。

code:

#include<bits/stdc++.h>
using namespace std;
template<class T>inline void init(T&x){x=0;char ch=getchar();bool t=0;for(;ch>'9'||ch<'0';ch=getchar()) if(ch=='-')t=1;for(;ch>='0'&&ch<='9';ch=getchar()) x=(x<<1)+(x<<3)+(ch-48);if(t) x=-x;return;
}
const int N=1.5e5+10;
int n,m,tp,RT;
typedef long long ll;
int dep[N],fa[N];ll dis[N];
struct edge{int to,next,w;
}a[N<<1];
int LIM;int head[N],cnt=0;
inline void add(int x,int y,int z){a[++cnt]=(edge){y,head[x],z};head[x]=cnt;}
int id[N],dfn[N],size[N],top[N],son[N],I=0,Ret[N];
namespace LISAN{int age[N],id[N];inline bool cmp(int i,int j){return age[i]<age[j];}inline int Lower(register int x){register int l=1,r=n,pos=n+1;while(l<=r){register int mid=l+r>>1;if(age[id[mid]]>=x) pos=mid,r=mid-1;else l=mid+1;}return pos;}void Prepare(){for(int i=1;i<=n;++i) id[i]=i,init(age[i]);sort(id+1,id+1+n,cmp);return;}
}using LISAN::Lower;
void Dfs(int u){size[u]=1;for(int v,i=head[u];i;i=a[i].next){v=a[i].to;if(v==fa[u]) continue;fa[v]=u,dep[v]=dep[u]+1;dis[v]=dis[u]+a[i].w;Ret[v]=a[i].w;Dfs(v);size[u]+=size[v];if(!son[u]||size[v]>size[son[u]]) son[u]=v;}return;
}
void dfs(int u,int t){top[u]=t;id[u]=++I,dfn[I]=u;if(!son[u]) return;dfs(son[u],t);for(int v,i=head[u];i;i=a[i].next) if((v=a[i].to)==son[u]||v==fa[u]) continue;else dfs(v,v);return;
}
ll Sum[N],SR[N];
const int MAXN=N*100;
int ls[MAXN],rs[MAXN],vis[MAXN],rt[N];
ll E[MAXN];int F[MAXN];int cur=0,NOW=0;
void Build(int &u,int l,int r){u=++cur;E[u]=F[u]=0;if(l==r) return;int mid=(l+r)>>1;Build(ls[u],l,mid);Build(rs[u],mid+1,r);return;
}
void Modify(int&u,int l,int r,int L,int R){if(L>R) return;int p=u;if(vis[p]!=NOW) {p=++cur;ls[p]=ls[u],rs[p]=rs[u];E[p]=E[u],F[p]=F[u];vis[p]=NOW;u=p;}E[p]+=SR[R]-SR[L-1];if(l>=L&&r<=R) {++F[p];return;}int mid=l+r>>1;if(mid>=R) return Modify(ls[p],l,mid,L,R);if(mid< L) return Modify(rs[p],mid+1,r,L,R);Modify(ls[p],l,mid,L,mid);Modify(rs[p],mid+1,r,mid+1,R);return;
}inline void Modify(int &rt,int u){++NOW;while(top[u]) {Modify(rt,1,n,id[top[u]],id[u]);u=fa[top[u]];}return;
}
void Query(int v,int u,int l,int r,int L,int R,ll&ans){if(L>R) return;if(!u&&!v) return;if(l>=L&&r<=R) {ans+=E[u]-E[v];return;}ans+=(SR[R]-SR[L-1])*(F[u]-F[v]);int mid=l+r>>1;if(mid>=R) return Query(ls[v],ls[u],l,mid,L,R,ans);if(mid< L) return Query(rs[v],rs[u],mid+1,r,L,R,ans);return Query(ls[v],ls[u],l,mid,L,mid,ans),Query(rs[v],rs[u],mid+1,r,mid+1,R,ans);
}
inline ll Query(int l,int r,int u){ll res=0;while(top[u]) Query(rt[l],rt[r],1,n,id[top[u]],id[u],res),u=fa[top[u]];return res;
}
void work(){int lst=0;Dfs(1),dfs(1,1);for(int i=1;i<=n;++i) SR[i]=SR[i-1]+Ret[dfn[i]];Build(rt[0],1,n);for(int i=1;i<=n;++i) Sum[i]=Sum[i-1]+dis[LISAN::id[i]],rt[i]=rt[i-1],Modify(rt[i],LISAN::id[i]);for(int i=1;i<=m;++i) {int l,r,x;init(x),init(l),init(r);l=(l+lst)%LIM,r=(r+lst)%LIM;if(l>r) swap(l,r);l=Lower(l);r=Lower(r+1)-1;ll ans=0;ans=Query(l-1,r,x);ans=(Sum[r]-Sum[l-1])+(ll)(r-l+1)*dis[x]-(ans<<1);printf("%lld\n",ans);lst=ans%LIM;}
}
int main()
{init(n),init(m),init(LIM);LISAN::Prepare();int u,v,w;for(int i=1;i<n;++i) {init(u),init(v),init(w);add(u,v,w);add(v,u,w);}work();return 0;
}

转载于:https://www.cnblogs.com/NeosKnight/p/10502660.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/365407.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

windows中的项目拷贝到linux中,部分数据不显示的原因

linux严格区分大小写&#xff0c;可能是数据表名大小写导致的。 如上传文件不成功&#xff0c;可能是系统权限导致的。转载于:https://www.cnblogs.com/miaoxingren/p/9784743.html

java并发数据共享机制_Java并发编程:核心理论之数据共享性

原标题&#xff1a;Java并发编程&#xff1a;核心理论之数据共享性并发编程是Java程序员最重要的技能之一&#xff0c;也是最难掌握的一种技能。它要求编程者对计算机最底层的运作原理有深刻的理解&#xff0c;同时要求编程者逻辑清晰、思维缜密&#xff0c;这样才能写出高效、…

调用天气预报接口

方案一&#xff1a; 浏览器由于安全的限制&#xff0c;不允许跨域访问。但是PHP服务器是允许的。我们可以通过使用PHP文件做代理&#xff0c;通过PHP来调用接口。 详细接口分析可参看&#xff1a;http://www.cnblogs.com/wangjingblogs/p/3192953.html 返回JSON格式 PHP代码…

测试集准确率不变_这个医疗AI准确率突破天际,招来了铺天盖地的质疑

转自 | 量子位只要输入一次心跳的波谱。就能判断一个人有没有发生心力衰竭 (CHF) &#xff0c;准确率100%。这是英国华威大学领衔的团队&#xff0c;用机器学习方法做出的新成果。还登上了影响因子2.943的Biomedical Signal Processing and Control期刊。准确率眼看就要突破天际…

JavaFX自定义控件– Nest Thermostat第1部分

几周前&#xff0c;由于Hendrik Ebbers的出色文章 &#xff0c;我决定花一些时间观看有关JavaFX的JavaOne讨论。 我不得不说我已经学到了很多东西&#xff0c;只是看这些视频&#xff08;即使我还没有完成&#xff09;&#xff01; Gerrit的“使用力&#xff0c;路克”或使用J…

PHP涉及的所有英文单词

PHP涉及的所有英文单词拦路虎 PHP再火&#xff0c;也会让一部同学心生畏惧&#xff0c;因为看到编辑器中那一串串英文单词&#xff0c;担心自己英文不好&#xff0c;从而对能学会PHP的决心产生动摇。其实大可不必&#xff0c;英文在学习PHP过程中真的连级别都够不上&#xff0c…

java 不编译咋办_java – 为什么JVM不编译整个程序,而不是逐个编译?

他所说的是,在运行时将所有字节码编译成机器语言是不切实际的.您可以预先编译所有内容,但这并不是JIT所采用的方法.一方面,不知道程序有多大.人们在30分钟的启动时会相当不高兴,因为它编译了可以找到的每个库(给定的Java程序不在一个文件中,它可以访问类路径中的所有内容)对于另…

mysql .pdb是什么文件_计算广告算法到底要做什么?

这个话题在这个专栏开篇就该去讲。恰逢今天公司业务和财务培训(20190216)之后&#xff0c;也有一些思索&#xff0c;索性就都汇总写下来。本文杂述&#xff0c;不尽完备&#xff0c;但是值得不断完善。我喜欢一句话“革命不是请客吃饭&#xff0c;不是做文章&#xff0c;不是绘…

浅析inline-block--使用inline-block创建布局

inline-block前端程序猿们肯定不陌生&#xff0c;它是display属性的一个取值。 之所以称之为inline-block。是因为它兼具行内元素(inline-element)和块级元素(block-element)的特征。 块级元素&#xff08;block elements&#xff09;,来源于CSS盒子模型。块级元素包含width h…

Cookie和Session版的登录验证

URL : from django.conf.urls import url from app01 import viewsurlpatterns [url(r^login/, views.login),url(r^home/, views.home),url(r^index/, views.index), ] 前端 : <form action"" method"post">{% csrf_token %}<input type"t…

Java 8 Friday Goodies:java.io终于成功了!

在Data Geekery &#xff0c;我们喜欢Java。 而且&#xff0c;由于我们真的很喜欢jOOQ的流畅的API和查询DSL &#xff0c;我们对Java 8将为我们的生态系统带来什么感到非常兴奋。 我们已经写了一些关于Java 8好东西的博客 &#xff0c;现在我们觉得是时候开始一个新的博客系列了…

ASP.NET获取客户端、服务器端基础信息

1. 在ASP.NET中专用属性&#xff1a;获取服务器电脑名&#xff1a;Page.Server.ManchineName获取用户信息&#xff1a;Page.User获取客户端电脑名&#xff1a;Page.Request.UserHostName获取客户端电脑IP&#xff1a;Page.Request.UserHostAddress2. 在网络编程中的通用方法&am…

java json decode 中文_关于json_decode乱码及NULL的解决方法

写接口的同学应该会经常遇到数据格式的转换&#xff0c;这时候必不可少的两个函数就是json_encode()和json_decode()。这两个函数使用的时候有很多的主要事项&#xff0c;在这里我来说一下json_decode()。json_decode():对JSON 格式的字符串进行解码,接受一个JSON 格式的字符串…

syslog可能引起得问题_牙齿经常有问题?可能是这4个坏习惯引起的,要改正

很多人明明很年轻&#xff0c;却得了很多牙齿疾病&#xff0c;甚至到了换牙的地步。牙齿虽然是最为坚硬的身体器官&#xff0c;但是即使再坚硬也是容易受到伤害的&#xff0c;日常生活中有很多小事都会造成对牙齿的伤害&#xff0c;想要保护牙齿&#xff0c;一定要改正一下这几…

jq实现前端文件上传

FormData FormData是XMLHttpRequest Level 2 新增的一个接口。 使用FormData可以实现各种文件上传。 使用 // 创建FormData的实例 var formdata new FormData();// 用append()为实例添加键和值 formdata.append(键名, 键值); 注意 使用jq的$.ajax()方法来进行文件上传时&am…

使用JUnitParams进行参数化的JUnit测试

参数化的单元测试用于在不同条件下测试相同的代码。 借助参数化的单元测试&#xff0c;我们可以建立一种测试方法&#xff0c;该方法从某些数据源中检索数据。 该数据源可以是测试数据对象&#xff0c;外部文件甚至数据库的集合。 一般的想法是使使用相同的单元测试方法测试不同…

js webpack 解决跨域问题_webpack-dev-server 作代理解决跨域,让你的本地开发飞起来...

最近在接到一个需求是做一个可视化的监控系统&#xff0c;mock数据来开发的话实在不太方便&#xff0c;况且数据量之大。查了一下资料&#xff0c;可以用webpack-dev-server作为代理&#xff0c;直接请求线上&#xff0c;哈哈哈&#xff0c;是不是很方便。### 目前我用的是webp…

代码片段 欢迎补充 一起共享

python&#xff1a; https://github.com/Lj-github/pythonTool转载于:https://www.cnblogs.com/liujiang04/p/9787486.html

实现用户操作指引功能

主要是通过定位找到需要指引的目标元素&#xff0c;然后再在蒙版上画一个div&#xff0c;设置为白色&#xff0c;定位到目标元素位置。思路大概就是这样。 图一&#xff1a; ![](https://img2018.cnblogs.com/blog/1354858/201811/1354858-20181105141942044-1763163359.png) 图…

扩展Guava缓存溢出到磁盘

缓存使您可以轻松地显着加速应用程序。 Java平台的两种出色的缓存实现是Guava缓存和Ehcache 。 尽管Ehcache功能丰富得多&#xff08;例如其Searchable API &#xff0c;将缓存持久化到磁盘或溢出到大内存的可能性&#xff09;&#xff0c;但与Guava相比&#xff0c;它也带来了…