http://www.lydsy.com/JudgeOnline/problem.php?id=3091 (题目链接)

题意

  给出一棵无根树,维护四个操作。link,cut,路径加法,路径期望查询。

Solution

  右转题解→_→:PoPoQQQ

  对于无法直接维护的值,我们可以考虑做差,或者是用别的比较好维护的值来加减乘除得到。

细节

  全程LL,先翻转再打标记。

代码

// bzoj3091
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<map>
#define LL long long
#define inf 2147483640
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout)
using namespace std; const int maxn=50010;
int n,m,fa[maxn];
struct node {
int son[2];
LL sum,tag,rev,ans,val,lsum,rsum,size;
int& operator [] (int x) {return son[x];}
}tr[maxn]; LL gcd(LL a,LL b) {return b==0 ? a : gcd(b,a%b);}
namespace LCT {
void reverse(int k) {
swap(tr[k][0],tr[k][1]);
swap(tr[k].lsum,tr[k].rsum);
tr[k].rev^=1;
}
void add(int k,LL val) {
tr[k].val+=val;
tr[k].sum+=tr[k].size*val;
tr[k].tag+=val;
tr[k].ans+=tr[k].size*(tr[k].size+1)*(tr[k].size+2)/6*val;
tr[k].lsum+=tr[k].size*(tr[k].size+1)/2*val;
tr[k].rsum+=tr[k].size*(tr[k].size+1)/2*val;
}
void pushdown(int k) {
if (tr[fa[k]][0]==k || tr[fa[k]][1]==k) pushdown(fa[k]);
int l=tr[k][0],r=tr[k][1];
if (tr[k].rev) {
if (l) reverse(l);
if (r) reverse(r);
tr[k].rev^=1;
}
if (tr[k].tag) {
if (l) add(l,tr[k].tag);
if (r) add(r,tr[k].tag);
tr[k].tag=0;
}
}
void pushup(int k) {
int l=tr[k][0],r=tr[k][1];
tr[k].size=tr[l].size+tr[r].size+1;
tr[k].lsum=tr[l].lsum+(tr[l].size+1)*tr[k].val+tr[r].lsum+tr[r].sum*(tr[l].size+1);
tr[k].rsum=tr[r].rsum+(tr[r].size+1)*tr[k].val+tr[l].rsum+tr[l].sum*(tr[r].size+1);
tr[k].sum=tr[l].sum+tr[r].sum+tr[k].val;
tr[k].ans=tr[l].ans+tr[r].ans+tr[l].lsum*(tr[r].size+1)+tr[r].rsum*(tr[l].size+1)+tr[k].val*(tr[l].size+1)*(tr[r].size+1);
}
void rotate(int x) {
int y=fa[x],z=fa[y],l,r;
l=tr[y][1]==x;r=l^1;
if (tr[z][0]==y || tr[z][1]==y) tr[z][tr[z][1]==y]=x;
fa[tr[x][r]]=y;fa[x]=z;fa[y]=x;
tr[y][l]=tr[x][r];tr[x][r]=y;
pushup(y);pushup(x);
}
void splay(int x) {
pushdown(x);
while (tr[fa[x]][0]==x || tr[fa[x]][1]==x) {
int y=fa[x],z=fa[y];
if (tr[z][0]==y || tr[z][1]==y) {
if (tr[z][0]==y ^ tr[y][0]==x) rotate(x);
else rotate(y);
}
rotate(x);
}
}
void access(int x) {
for (int y=0;x;y=x,x=fa[x]) splay(x),tr[x][1]=y,pushup(x);
}
void makeroot(int x) {
access(x);splay(x);reverse(x);
}
void link(int x,int y) {
makeroot(x);fa[x]=y;
}
void cut(int x,int y) {
makeroot(x);access(y);splay(y);
if (tr[y][0]==x && tr[x][1]==0)
tr[y][0]=0,fa[x]=0,pushup(y);
}
void modify(int x,int y,LL val) {
makeroot(x);access(y);splay(y);add(y,val);
}
int find(int x) {
return fa[x] ? find(fa[x]) : x;
}
void query(int x,int y) {
makeroot(x);access(y);splay(y);
LL A=tr[y].ans,B=tr[y].size*(tr[y].size+1)/2;
LL D=gcd(A,B);
printf("%lld/%lld\n",A/D,B/D);
}
}
using namespace LCT; int main() {
scanf("%d%d",&n,&m);
for (int i=1;i<=n;i++) scanf("%lld",&tr[i].val);
for (int u,v,i=1;i<n;i++) {
scanf("%d%d",&u,&v);
link(u,v);
}
for (int op,x,y,d,i=1;i<=m;i++) {
scanf("%d%d%d",&op,&x,&y);
if (op==1) if (find(x)==find(y)) cut(x,y);
if (op==2) if (find(x)!=find(y)) link(x,y);
if (op==3) {scanf("%d",&d);if (find(x)==find(y)) modify(x,y,d);}
if (op==4) if (find(x)==find(y)) query(x,y);else puts("-1");
}
return 0;
}

【bzoj3091】 城市旅行的更多相关文章

  1. 【LCT】BZOJ3091 城市旅行

    3091: 城市旅行 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1927  Solved: 631[Submit][Status][Discuss ...

  2. BZOJ3091 城市旅行 LCT

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ3091 题意概括 鉴于本人语文不好,此题的描述原题很清晰,废话不多,请看原题. 可怕,原题是图片,不 ...

  3. BZOJ3091: 城市旅行

    Description Input Output Sample Input 4 5 1 3 2 5 1 2 1 3 2 4 4 2 4 1 2 4 2 3 4 3 1 4 1 4 1 4 Sample ...

  4. BZOJ3091城市旅行——LCT区间信息合并

    题目描述 输入 输出 样例输入 4 5 1 3 2 5 1 2 1 3 2 4 4 2 4 1 2 4 2 3 4 3 1 4 1 4 1 4 样例输出 16/3 6/1 提示 对于所有数据满足 1& ...

  5. BZOJ3091: 城市旅行(LCT,数学期望)

    Description Input Output Sample Input 4 5 1 3 2 5 1 2 1 3 2 4 4 2 4 1 2 4 2 3 4 3 1 4 1 4 1 4 Sample ...

  6. bzoj3091 城市旅行 LCT + 区间合并

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=3091 题解 调了整个晚自习才调出来的问题. 乍一看是个 LCT 板子题. 再看一眼还是个 LC ...

  7. 【BZOJ3091】城市旅行 LCT

    [BZOJ3091]城市旅行 Description Input Output Sample Input 4 5 1 3 2 5 1 2 1 3 2 4 4 2 4 1 2 4 2 3 4 3 1 4 ...

  8. BZOJ 3091: 城市旅行 [LCT splay 期望]

    3091: 城市旅行 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1454  Solved: 483[Submit][Status][Discuss ...

  9. luogu P4842 城市旅行

    嘟嘟嘟 好题,好题 刚开始突发奇想写了一个\(O(n ^ 2)\)暴力,结果竟然过了?!后来才知道是上传题的人把单个数据点开成了10s-- 不过不得不说我这暴力写的挺好看的.删边模仿链表删边,加边的时 ...

随机推荐

  1. html元素的分类以及特点

    解释几个概念: 替换元素:官方解释是,一个内容不受css视觉格式化模型控制,css渲染模型并不考虑对此内容的渲染,且元素一般拥有固定的尺寸,(高度,宽度)的元素,被称为置换元素.通俗来说就是浏览器根据 ...

  2. C语言中猴子吃桃问题

    猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个.第二天早上又将第一天剩下的桃子吃掉一半,有多吃了一个.以后每天早上都吃了前一天剩下的一半零一个.到第 10 天早上想再吃时 ...

  3. 20155204 2016-2017-2 《Java程序设计》第1周学习总结

    20155204 2016-2017-2 <Java程序设计>第1周学习总结 一.学习考核方式,理解成绩构成 首先是100分的构成,主要分为周考的总计60,实验的15分,团队项目(博客报告 ...

  4. 20155220 Exp9 Web安全基础实践

    Exp9 Web安全基础实践 实验过程 开启webgoat 输入java -jar webgoat-container-7.1-exec.jar,来运行webgoat 在浏览器输入localhost: ...

  5. 20155331 《网络对抗》 Exp6 信息搜集与漏洞扫描

    20155331 <网络对抗> Exp6 信息搜集与漏洞扫描 实验问题回答 哪些组织负责DNS,IP的管理 答:美国政府授权ICANN统一管理全球根服务器,负责全球的域名根服务器.DNS和 ...

  6. 全方位Bindind分析

    Binding,音译为绑定,通道捆她想一条数据的高速绑着“源”与“目标”: “源”乃提供数据的一方:“目标”乃接收数据并作出相应反应的一方: 过程感觉就像是,给一个“激励”,就会作出“反应”那样--- ...

  7. 【转载】WINAPI宏

    原文:http://blog.sina.com.cn/s/blog_3f27dee60100qi4j.html 一直搞不懂为什么在函数前面加上WINAPI.CALLBACK等是什么意思 又不是返回值 ...

  8. 使用 Vue.js 2.0+ Vue-resource 模仿百度搜索框

    使用 Vue.js 2.0 模仿百度搜索框 <!DOCTYPE html> <html> <head> <meta charset="utf-8&q ...

  9. Spring MVC统一异常处理

    实际上Spring MVC处理异常有3种方式: (1)一种是在Controller类内部使用@ExceptionHandler使用注解实现异常处理: 可以在Controller内部实现更个性化点异常处 ...

  10. SQL Server 全文搜索

    SQL Server 的全文搜索(Full-Text Search)是基于分词的文本检索功能,依赖于全文索引.全文索引不同于传统的平衡树(B-Tree)索引和列存储索引,它是由数据表构成的,称作倒转索 ...