首先 \(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 题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

  10. JSOI2016R3 瞎BB题解

    题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...

随机推荐

  1. MySQL中INSERT INTO ... ON DUPLICATE KEY UPDATE浅析

    最近在做一个阅读次数的需求的时候,有这样一个场景,如果数据库中没有数据,就进行INSERT操作,有数据的话,阅读次数就+1.此处有两种实现方式,一种是想将数据查出来,在Java中进行处理,没有就INS ...

  2. uniapp 使用pinpa 持续化更新

    安装依赖 npm i pinia npm i pinia-plugin-persistedstate 新建 index.ts import { createPinia } from 'pinia' i ...

  3. C# 之 Int16 Int32 Int64 的区别-迷恋自留地

    int16 值类型表示值介于 -32768 到 +32767 之间的有符号整数. Int32 值类型表示值介于 -2,147,483,648 到 +2,147,483,647 之间的有符号整数. In ...

  4. Prometheus 3.0.0 升级中遇到的 `--storage.tsdb.retention` 错误的修复方法

    在将 Prometheus 升级到 3.0.0 后,许多用户会遇到以下错误: Error parsing command line arguments: unknown long flag '--st ...

  5. ChatGPT生成测试用例的最佳实践(一)

    前面介绍的案例主要展示了ChatGPT在功能.安全和性能测试用例生成方面的应用和成果.通过ChatGPT生成测试用例,测试团队不仅可以提升工作效率,还可以加快测试工作的速度,尽早发现被测系统中的问题. ...

  6. gitlab16 gitlab-runner

    gitlab-runner verify --delete FederatedKMeansSecureModelInference gitlab-runner register  --url http ...

  7. [转]在MyBatis中使用pageHelper5.1.9分页插件实现物理分页

    pagehelper的GIT地址:https://github.com/pagehelper/Mybatis-PageHelper/ 废话少说,直接给出中文官方链接: 1.如何使用分页插件 2.HOW ...

  8. [转]VC++中如何快速创建多层文件夹

    在创建目录时,原来的可用的方法是 _mkdir()或 BOOL CreateDirectory( LPCTSTR lpPathName, LPSECURITY_ATTRIBUTES lpSecurit ...

  9. Angular(一) - Typescript&Angular入门熟悉

    1. Typescript 1.1 安装typescript 1.2 typescript的小例子 1.2.1 新建一个index.ts 1.2.2 编译ts成js 1.2.3 查看生成的index. ...

  10. docker和主机之间文件传输

    docker和主机之间文件传输 1.从docker内部向主机传输文件 语法: docker cp [OPTIONS] CONTAINER:SRC_PATH DEST_PATH|- 示例:将容器96f7 ...