[NoiPlus2016]天天爱跑步
巨坑
树剖学的好啊!---sfailsth
把一段路径拆成两段,向上和S->LCA,向下LCA->T
用维护重链什么的操作搞一下。
sfailsth学长真不容易啊。。。考场上rush了4.58KB代码。。。。
常数巨大懒得优化,最慢一个点1528ms/128703KB,Orz
#include <iostream>
#include <cstring>
#include <vector>
#include <cstdio>
using namespace std;
const int N=600000;
int read() {
int ret=0,f=1; char ch=getchar();
while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();}
while (ch>='0'&&ch<='9'){ret*=10;ret+=ch-'0';ch=getchar();}
return ret*f;
}
struct Edge {
int to,nxt;
}e[N];
struct Peo {
int s,t,lca;
} p[N];
int n,m,w[N],top[N],dfn1[N],son[N],siz[N],dep[N],fa[N],tim,dfn2[N],f[N],rnk[N],ans[N],s[N],head[N],ecnt;
void add(int bg,int ed){e[++ecnt].nxt=head[bg];e[ecnt].to=ed;head[bg]=ecnt;}
bool vis[N];
int find(int x) {
return x==f[x]?x:f[x]=find(f[x]);
}
vector<int>Q[N],ID[N],S[N],T[N];
void dfs1(int x) {
siz[x]=1;
for(int i=head[x]; i; i=e[i].nxt) {
int v=e[i].to;
if(v==fa[x])continue;
fa[v]=x;
dep[v]=dep[x]+1;
dfs1(v);
siz[x]+=siz[v];
if(siz[v]>siz[son[x]]) son[x]=v;
}
}
void dfs2(int x,int qtop) {
dfn1[x]=++tim;
top[x]=qtop;
rnk[tim]=x;
if(son[x]) dfs2(son[x],qtop);
for(int i=head[x]; i; i=e[i].nxt) {
int v=e[i].to;
if(v==fa[x]||v==son[x]) continue;
dfs2(v,v);
}
dfn2[x]=tim;
}
void dfs3(int x) {
f[x]=x;
vis[x]=1;
for(int i=0; i<Q[x].size(); i++)
if(vis[Q[x][i]])
p[ID[x][i]].lca=find(Q[x][i]);
for(int i=head[x]; i; i=e[i].nxt)
if(fa[x]!=e[i].to)
dfs3(e[i].to),f[e[i].to]=x;
return;
}
void add(int x,int y,int depth) {
if(dep[x]<dep[y]) swap(x,y);
while(top[x]!=top[y]) {
if(dep[top[x]]<dep[top[y]]) swap(x,y);
S[dfn1[top[x]]].push_back(depth);
T[dfn1[x]+1].push_back(depth);
x=fa[top[x]];
}
if(dep[x]<dep[y])swap(x,y);
S[dfn1[y]].push_back(depth);
T[dfn1[x]+1].push_back(depth);
}
void calc1() {
for(int i=1; i<=n; i++) w[i]-=dep[i];
for(int i=1; i<=m; i++) {
int now=dep[p[i].s]-dep[p[i].lca];
if(w[p[i].lca]==now-dep[p[i].lca]) ans[p[i].lca]--;
add(p[i].lca,p[i].t,now-dep[p[i].lca]);
}
for(int i=1; i<=n; i++) {
for(int j=0; j<S[i].size(); j++)
s[S[i][j]]++;
for(int j=0; j<T[i].size(); j++)
s[T[i][j]]--;
ans[rnk[i]]+=s[w[rnk[i]]];
}
}
void calc2() {
for(int i=0; i<=n; i++) S[i].clear(),T[i].clear();
memset(s,0,sizeof s);
for(int i=1; i<=n; i++) w[i]+=dep[i]<<1;
for(int i=1; i<=m; i++)
add(p[i].lca,p[i].s,dep[p[i].s]);
for(int i=1; i<=n; i++) {
for(int j=0; j<S[i].size(); j++) s[S[i][j]]++;
for(int j=0; j<T[i].size(); j++) s[T[i][j]]--;
ans[rnk[i]]+=s[w[rnk[i]]];
}
}
int main() {
n=read(),m=read();
for(int i=1,u,v; i<n; i++)
u=read(),v=read(),add(u,v),add(v,u);
for(int i=1; i<=n; i++)
w[i]=read();
for(int u,v,i=1; i<=m; i++) {
u=read(),v=read();
Q[u].push_back(v);
Q[v].push_back(u);
ID[u].push_back(i);
ID[v].push_back(i);
p[i].s=u;
p[i].t=v;
}
dfs1(1);
dfs2(1,1);
dfs3(1);
calc1();
calc2();
for(int i=1; i<=n; i++) printf("%d ",ans[i]);
}
[NoiPlus2016]天天爱跑步的更多相关文章
- UOJ261 【NOIP2016】天天爱跑步
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...
- BZOJ4719 [Noip2016]天天爱跑步
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...
- noip2016天天爱跑步
题目描述 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.«天天爱跑步»是一个养成类游戏,需要玩家每天按时上线,完成打卡任务. 这个游戏的地图可以看作一一棵包含 个结点 ...
- bzoj 4719: [Noip2016]天天爱跑步
Description 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.?天天爱跑步?是一个养成类游戏,需要 玩家每天按时上线,完成打卡任务.这个游戏的地图可以看作一一 ...
- [NOIP]2016天天爱跑步
[NOIP]2016天天爱跑步 标签: LCA 树上差分 NOIP Description 小C同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.<天天爱跑步>是 ...
- NOIP2016 天天爱跑步 80分暴力
https://www.luogu.org/problem/show?pid=1600 题目描述 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.«天天爱跑步»是一个养 ...
- [NOIp 2016]天天爱跑步
Description 小C同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.<天天爱跑步>是一个养成类游戏,需要玩家每天按时上线,完成打卡任务. 这个游戏的地图 ...
- 【NOIP2016】【LCA】【树上差分】【史诗级难度】天天爱跑步
学弟不是说要出丧题吗>>所以我就研究了1天lca又研究了1天tj然后研究了一天天天爱跑步,终于写了出来.(最后的平均用时为240ms...比学弟快了1倍...) 题意:给你颗树,然后有m个 ...
- 【NOIP2016】天天爱跑步
题目描述 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.«天天爱跑步»是一个养成类游戏,需要玩家每天按时上线,完成打卡任务. 这个游戏的地图可以看作一一棵包含 个结点 ...
随机推荐
- C#--进程-线程
线程 线程也被称为轻量级进程lightweight process ,LWP,线程是CPU独立调度和分派的基本单位,同一个进程中的多个线程将共享该进程中的全部系统资源,多线程共享堆heap资源,c#程 ...
- faster-rcnn代码阅读1
毫无疑问,faster-rcnn是目标检测领域的一个里程碑式的算法.本文主要是本人阅读python版本的faster-rcnn代码的一个记录,算法的具体原理本文也会有介绍,但是为了对该算法有一个整体性 ...
- [Cypress] Find and Test Focused Input with Chrome’s DevTools in Cypress
In this lesson, we’ll add tests that finds a focused input. We’ll use Chrome’s dev tools from inside ...
- Github Pages 建立过程记录
之前建立过一个測试页面. 如今在折腾CreateJS 试着把离线版的文档传到github pages上面. 第一步:创建Repository 第二步:本地初始化 主要命令:git init 第三步:复 ...
- Linux查找并杀死僵尸进程
1.查看系统是否有僵尸进程 使用Top命令查找,当zombie前的数量不为0时,即系统内存在相应数量的僵尸进程. 2.定位僵尸进程 使用命令ps -A -ostat,ppid,pid,cmd |gre ...
- WPF中StringToImage和BoolToImage简单用法
在WPF的绑定控件操作中,经常会通过bool值或者某些特定的string值做出相应动作.但UI层控件的很多属性对应的都不是Bool值或者对应的只是固定的String值. 这个时候有两方法解决该问题. ...
- 应用MVP模式对遗留代码进行重构
AV(Autonomous View)自治视图 在面向终端用户的应用中,都需要一个可视化的UI来与用户交互.这个UI称为View视图. 在早期,我们习惯将所有前台的逻辑,与视图揉在一起,称为AV自治视 ...
- WordPress瀑布流主题PinThis中文版v1.6.8
PinThis主题来源于英语网站http://pinthis.pixelbeautify.com/的汉化(语言文件+控制面板),中文版采用的是翻译器手工核对,并不完美,只对主题中文化,其他没做任何更改 ...
- epoll的实现与深入思考
提契 纸上得来终觉浅,绝知此事要躬行. 正文 前段时间写了一篇epoll的学习文章,但没有自己的心得总觉得比较肤浅,花了一些时间补充一个epoll的实例,并浅析一下过程中遇到的问题. 上epoll_s ...
- -1.#IND000 &&图像类型转换
(1):float acos(float x) 参数x的范围为-1.0f到1.0f之间,返回值范围在0.0f到3.141592653f之间,值得注意的是:当x超出[-1.0f,1.0f]这个范围时此函 ...