[CF494D] Birthday 题解
首先 \(S(u)\) 显然是 \(u\) 的子树。
假如 \(u\) 是定点,问题转化为区间求平方和,十分简单。
于是我们用线段树维护区间平方和,支持区间加,然后离线问题,在 \(u\) 的位置处理即可。线段树从 \(fa\) 转移到 \(u\) 是极度简单的。
时间复杂度 \(O(n\log n)\)。
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int N=1e5+5,M=4e5+5,p=1e9+7;
int n,q,dfn[N],low[N],sm[M],pw[M],ad[M],as[N];
vector<int>g[N],w[N],qu[N],nm[N];int id,dis[N];
void push_up(int x){
sm[x]=(sm[x*2]+sm[x*2+1])%p;
pw[x]=(pw[x*2]+pw[x*2+1])%p;
}void down(int x,int a,int len){
pw[x]=(pw[x]+sm[x]*a*2+len*a%p*a)%p;
sm[x]=(sm[x]+len*a)%p,ad[x]=(ad[x]+a)%p;
}void push_down(int x,int ln,int rn){
down(x*2+1,ad[x],rn);
down(x*2,ad[x],ln),ad[x]=0;
}void add(int x,int l,int r,int L,int R,int v){
if(L<=l&&r<=R)
return down(x,v,r-l+1);
int mid=(l+r)/2;
push_down(x,mid-l+1,r-mid);
if(L<=mid) add(x*2,l,mid,L,R,v);
if(R>mid) add(x*2+1,mid+1,r,L,R,v);
push_up(x);
}int sum(int x,int l,int r,int L,int R){
if(L<=l&&r<=R) return pw[x];
int mid=(l+r)/2,re=0;
push_down(x,mid-l+1,r-mid);
if(R>mid) re=sum(x*2+1,mid+1,r,L,R);
if(L<=mid) re+=sum(x*2,l,mid,L,R);
return re;
}void dfs1(int x,int fa){
dfn[x]=++id;
add(1,1,n,id,id,dis[x]);
for(int i=0;i<g[x].size();i++){
int y=g[x][i],c=w[x][i];
if(y==fa) continue;
dis[y]=(dis[x]+c)%p,dfs1(y,x);
}low[x]=id;
}void dfs2(int x,int fa){
for(int i=0;i<g[x].size();i++){
int y=g[x][i],c=w[x][i];
if(y==fa) continue;
add(1,1,n,dfn[y],low[y],-c-c);
add(1,1,n,1,n,c),dfs2(y,x);
add(1,1,n,dfn[y],low[y],c+c);
add(1,1,n,1,n,-c);
}for(int i=0;i<qu[x].size();i++)
as[nm[x][i]]=2*sum(1,1,n,dfn[qu[x][i]],low[qu[x][i]])-pw[1];
}signed main(){
ios::sync_with_stdio(0);
cin.tie(0),cout.tie(0);
cin>>n;
for(int i=1;i<n;i++){
int x,y,z;cin>>x>>y>>z;
g[x].push_back(y),g[y].push_back(x);
w[x].push_back(z),w[y].push_back(z);
}cin>>q,dfs1(1,0);
for(int i=1;i<=q;i++){
int x,y;cin>>x>>y;
qu[x].push_back(y);
nm[x].push_back(i);
}dfs2(1,0);
for(int i=1;i<=q;i++)
cout<<(as[i]%p+p)%p<<"\n";
return 0;
}
[CF494D] Birthday 题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
- JSOI2016R3 瞎BB题解
题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...
随机推荐
- 前端每日一知之opcity/visiblity/display隐藏元素对比
脑图在线链接 本文内容依据CSDN博主FEWY精彩文章总结而来原文链接
- 百度地图基本事件: marker、polygon等覆盖物添加以及删除
marker拖拽获取坐标 https://www.cnblogs.com/niunan/p/6822124.html 如果添加大量聚合点的时候,请参考如下几篇文章 https://www.zhih ...
- 【Vue】vite+vue3 如何实现点击进入详情页/文章页
如上图,点击标题可以进入详情页,关键代码截图如下: 然后去配置路由 那么组件如何从地址中接收参数呢
- 区分PO、VO、 BO、 DTO、 POJO
分层领域模型规约: DO(Data Object):此结构与数据库表结构一一对应,通过DTO向上传输数据源对象. DTO(Data Transfer Object):数据传输对象,Service ...
- 前后端分离模式下Java Web开发中的技术栈概图
参考链接1:前后端的分离模式 参考链接2:浅谈前后端分离开发模式 参考链接3:前后端分离开发模式介绍
- 长连接网关技术专题(十一):揭秘腾讯公网TGW网关系统的技术架构演进
本文由腾讯技术团队peter分享,原题"腾讯网关TGW架构演进之路",下文进行了排版和内容优化等. 1.引言 TGW全称Tencent Gateway,是一套实现多网统一接入,支持 ...
- IM跨平台技术学习(九):全面解密新QQ桌面版的Electron内存优化实践
本文由QQ技术团队分享,本文收录时有内容修订和大量排版优化. 1.引言 QQ 作为国民级应用,从互联网兴起就一直陪伴着大家,是很多用户刚接触互联网就开始使用的应用. 而 QQ 桌面版最近一次技术架构升 ...
- Unity TheHeretic Gawain Demo 异教徒Demo技术学习
<异教徒 Heretic>是Unity在2019年GDC大会上展示的一款技术Demo,部分资源于2020年中旬公开下载. 这款Demo主要用于展示Unity在数字人技术领域的最新进展,尤其 ...
- 记录一下关于谷歌浏览器的开发者插件之vue-devtools
在做vue进行开发的时候增加一个浏览器的插件进行开发可以做到游鱼得水,更加的舒适 在这里我留下一个git地址用来下载插件包 https://gitee.com/zhang_banglong/vue-d ...
- docker-compose部署下Fastapi中使用sqlalchemy和Alembic
本篇介绍使用Fastapi + sqlalchemy + alembic 来完成后端服务的数据库管理,并且通过docker-compose来部署后端服务和数据库Mysql.包括: 数据库创建,数据库用 ...