hihocoder 1347 小h的树上的朋友

时间:2022-09-22 08:06:00

传送门

时间限制:18000ms
单点时限:2000ms
内存限制:512MB

描述

小h拥有$n$位朋友。每位朋友拥有一个数值$V_i$代表他与小h的亲密度。亲密度有可能发生变化。
岁月流逝,小h的朋友们形成了一种稳定的树状关系。每位朋友恰好对应树上的一个节点。
每次小h想请两位朋友一起聚餐,他都必须把连接两位朋友的路径上的所有朋友都一起邀请上。并且聚餐的花费是这条路径上所有朋友的亲密度乘积。
小h很苦恼,他需要知道每一次聚餐的花销。小h问小y,小y当然会了,他想考考你。

输入

输入文件第一行是一个整数 $n$,表示朋友的数目,从 $1$ 开始编号。
输入文件第二行是 $n$ 个正整数 $V_i$,表示每位朋友的初始的亲密度。
接下来 $n-1$ 行,每行两个整数 $u$ 和 $v$,表示 $u$ 和 $v$ 有一条边。
然后是一个整数 $m$,代表操作的数目。每次操作为两者之一:
$0\ u\ v$ 询问邀请朋友 $u$ 和 $v$ 聚餐的花费

$1\  u\ v$ 改变朋友 $u$ 的亲密度为 $v$

$1\le n,m\le 5\times 10^5$

$V_i\le 10^9$

输出

对于每一次询问操作,你需要输出一个整数,表示聚餐所需的花费。你的答案应该模 $1,000,000,007$ 输出。
样例输入

3
    1 2 3
    1 2
    2 3
    5
    0 1 2
    0 1 3
    1 2 3
    1 3 5
    0 1 3

样例输出

2
    6
    15


Solution

比较裸的做法是树链剖分,我试了一发,但这题数据较大,会TLE ,不过据说LCT可以水过, 然而我不会LCT。

正解:DFS序 + 树状数组/线段树,询问和更新复杂度都是 $O(\log{n})$。

对节点 $u$,将根节点到 $u$ 的路径上的点的权值之积维护成前缀积,记作 $pro[u]$。

显然 $u$ 到 $v$ 路径上节点的权值之积可表示为:

\[\dfrac{pro[u] \times pro[v] \times a[lca(u, v)]}{(pro[lca(u, v)])^2},\]

上式中 $a[x]$ 表示节点 $x$ 的权值。

不过我一开始把这个式子搞错了:

\[\dfrac{pro[u]\times pro[v]}{pro[lca(u, v)]}\]

WA了N发,真是太SB了。。。

其他的坑点:

连乘时要边乘边模,否则会爆long long。

教训:

调用函数时要留意一下参数类型。

Implementation

#include <bits/stdc++.h>
using namespace std; const int N{<<}, M(1e9+);
typedef long long LL; LL bit[N];
int n; LL pro(int x){
LL res=;
for(; x; res=res*bit[x]%M, x-=x&-x);
return res;
} void mul(int x, int v){
for(; x&&x<=n; bit[x]=bit[x]*v%M, x+=x&-x);
} LL Pow(LL x, int n){
LL res=;
for(; n; x*=x, x%=M, n>>=)
if(n&) res*=x, res%=M;
return res;
} LL inv(int x){
return Pow(x, M-);
} int a[N], tail, fa[N][], dep[N], L[N], R[N];
vector<int> g[N]; void dfs(int u, LL p, int f){
fa[u][]=f, dep[u]=dep[f]+;
for(int i=; i<; i++) fa[u][i]=fa[fa[u][i-]][i-];
L[u]=++tail;
mul(tail, inv(pro(tail-))*p%M);
for(auto &v:g[u])
if(v!=f) dfs(v, p*a[v]%M, u);
R[u]=tail;
} int LCA(int u, int v){
if(dep[u]<dep[v]) swap(u, v);
int diff=dep[u]-dep[v];
for(int i=; i<; i++)
if(diff&<<i) u=fa[u][i];
if(u==v) return u;
for(int i=; i>=; i--)
if(fa[u][i] != fa[v][i]) u=fa[u][i], v=fa[v][i];
return fa[u][];
} int main(){
cin>>n;
for(int i=; i<=n; i++)
scanf("%d", a+i), bit[i]=; for(int u, v, i=; i<n; i++)
scanf("%d%d", &u, &v), g[u].push_back(v), g[v].push_back(u);
dfs(, a[], ); int m; cin>>m;
for(int t, u, v; m--; ){
scanf("%d%d%d", &t, &u, &v);
if(t==){
int w=LCA(u, v);
LL t=pro(L[w]);
LL res=pro(L[u])*pro(L[v])%M*inv(t*t%M)%M*a[w]%M;
printf("%lld\n", res); //error-prone
}
else{
mul(L[u], inv(a[u])*v%M), mul(R[u]+, a[u]*inv(v)%M), a[u]=v; //error-prone
}
}
}

hihocoder 1347 小h的树上的朋友的更多相关文章

  1. hihocoder-1347 小h的树上的朋友&lpar;lca&plus;线段树&rpar;

    题目链接: 小h的树上的朋友 时间限制:18000ms 单点时限:2000ms 内存限制:512MB 描述 小h拥有n位朋友.每位朋友拥有一个数值Vi代表他与小h的亲密度.亲密度有可能发生变化. 岁月 ...

  2. hihoCoder 1513 小Hi的烦恼

    hihoCoder 1513 小Hi的烦恼 思路: 用bitset判断交集个数 代码: #include<bits/stdc++.h> using namespace std; #defi ...

  3. 【渗透笔记】拿下某小H网的全过程

    自从班上A片小王子的7个T资源被封了以后,本小白为造福全班同学,尝试拿下个小H网,先用webrobot搜某些只有小H网才会出现的关键词 本以为直接导出放御剑里跑就行了,然并软.于是用awvs扫了一下, ...

  4. 一个简洁的小H车调运模型

    一个简洁的小H车调运模型 不久前, 帝都B城市到处都是小H车, 理想的小H车应该是布朗运动\均匀分布,可是现实上它们就是不均匀.于是有如下问题: 观察帝都 HD区SY村区域,将其划分成10个用车点,用 ...

  5. hihocoder&num;1513 &colon; 小Hi的烦恼 bitset

    目录 题目链接 题解 代码 题目链接 hihocoder#1513 : 小Hi的烦恼 题解 cdq 套cdq 套cdq 套cdq就完了呀 对每一科开n个bitset 表示该科目前i个有谁 每次查询都& ...

  6. 小H和密码

    链接:https://www.nowcoder.com/acm/contest/72/B来源:牛客网 题目描述     小H在击败怪兽后,被一个密码锁挡住了去路     密码锁由N个转盘组成,编号为1 ...

  7. 【Wannafly挑战赛10 - B】小H和密码&lpar;DP&rpar;

    试题链接:https://www.nowcoder.com/acm/contest/72/B 题目描述     小H在击败怪兽后,被一个密码锁挡住了去路     密码锁由N个转盘组成,编号为1~N,每 ...

  8. BZOJ1505&colon; &lbrack;NOI2004&rsqb;小H的小屋

    BZOJ1505: [NOI2004]小H的小屋 Description 小H发誓要做21世纪最伟大的数学家.他认为,做数学家与做歌星一样,第一步要作好包装,不然本事再大也推不出去. 为此他决定先在自 ...

  9. Wannafly挑战赛10:A题:小H和迷宫

    题目描述       小H陷入了一个迷宫中,迷宫里有一个可怕的怪兽,血量有N点,小H有三瓶魔法药水,分别可以使怪兽损失a%.b%.c%的血量(之后怪兽的血量会向下取整),小H想合理地运用这三瓶药水,使 ...

随机推荐

  1. 如何写一个简单的shell

    如何写一个简单的shell 看完<UNIX环境高级编程>后我就一直想写一个简单的shell来作为练习,因为有事断断续续的写了好几个月,如今写了差不多来总结一下. 源代码放在了Github: ...

  2. ArcGIS中利用ArcMap将地理坐标系转换成投影坐标系(从WKID&equals;4326到WKID&equals;102100)

    原文:ArcGIS中利用ArcMap将地理坐标系转换成投影坐标系(从WKID=4326到WKID=102100) 对于非地理专业的开发人员,对与这些生涩的概念,我们不一定都要了解,但是我们要理解,凡是 ...

  3. SDUT 2877&colon;angry&lowbar;birds&lowbar;again&lowbar;and&lowbar;again

    angry_birds_again_and_again Time Limit: 2000ms   Memory limit: 65536K  有疑问?点这里^_^ 题目描述 The problems ...

  4. Codeforces Round &num;348 &lpar;VK Cup 2016 Round 2&comma; Div&period; 2 Edition&rpar; D&period; Little Artem and Dance

    题目链接: http://codeforces.com/contest/669/problem/D 题意: 给你一个初始序列:1,2,3,...,n. 现在有两种操作: 1.循环左移,循环右移. 2. ...

  5. 【redis】05Redis的常用命令及高级应用

    Redis常用命令     Redis提供了非常丰富的命令,对数据库和个中数据类型进行操作, 这些命令呢,可以在Linux终端使用. 分为两大类的命令,一种是键值相关的命令,一种是服务器相关的命令, ...

  6. InstallShield 12 制作安装包

    目  录 一. 二. 三. (一) 打开project... 2 (二) project助手页面... 3 1.Application Information:程序信息... 4 2.Installa ...

  7. session fixation

    转自:session fixation攻击 什么是session fixation攻击 Session fixation有人翻译成"Session完成攻击",实际上fixation ...

  8. 让人恼火的经历——手机H5网页被注入广告

    你的网站是否在尾部出现了让人恼火的广告? 这次我算是遇到了这些流氓的广告.那么就让我们一步步攻克这些恼火的广告吧. 问题描述 某一天下午开始,我们制作的网站就开始被各种广告注入,类似上图这种. 还有在 ...

  9. SpringBoot构建RESTful service完成Get和Post

    一个基本的RESTfule service最进场向外提供的请求Method就是Get和Post. 在Get中,常用的都会在请求上带上参数,或者是路径参数.响应Json. 在Post中,常用的会提交fo ...

  10. &lpar;52&rpar;Wangdao&period;com第七天&lowbar;字面量&sol;变量&lowbar;标识符&lowbar;数据类型&lowbar;数据的存储

    JavaScript 字面量 和 变量 字面量:就是那些不可变的值,如1,2,100,2000,Infinity,NaN 变量: 变量,代表的当前随机分配的内存地址. 变量的值,是可变的,可以用来保存 ...