巨坑

树剖学的好啊!---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]天天爱跑步的更多相关文章

  1. UOJ261 【NOIP2016】天天爱跑步

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...

  2. BZOJ4719 [Noip2016]天天爱跑步

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...

  3. noip2016天天爱跑步

    题目描述 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.«天天爱跑步»是一个养成类游戏,需要玩家每天按时上线,完成打卡任务. 这个游戏的地图可以看作一一棵包含 个结点 ...

  4. bzoj 4719: [Noip2016]天天爱跑步

    Description 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.?天天爱跑步?是一个养成类游戏,需要 玩家每天按时上线,完成打卡任务.这个游戏的地图可以看作一一 ...

  5. [NOIP]2016天天爱跑步

    [NOIP]2016天天爱跑步 标签: LCA 树上差分 NOIP Description 小C同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.<天天爱跑步>是 ...

  6. NOIP2016 天天爱跑步 80分暴力

    https://www.luogu.org/problem/show?pid=1600 题目描述 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.«天天爱跑步»是一个养 ...

  7. [NOIp 2016]天天爱跑步

    Description 小C同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.<天天爱跑步>是一个养成类游戏,需要玩家每天按时上线,完成打卡任务. 这个游戏的地图 ...

  8. 【NOIP2016】【LCA】【树上差分】【史诗级难度】天天爱跑步

    学弟不是说要出丧题吗>>所以我就研究了1天lca又研究了1天tj然后研究了一天天天爱跑步,终于写了出来.(最后的平均用时为240ms...比学弟快了1倍...) 题意:给你颗树,然后有m个 ...

  9. 【NOIP2016】天天爱跑步

    题目描述 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.«天天爱跑步»是一个养成类游戏,需要玩家每天按时上线,完成打卡任务. 这个游戏的地图可以看作一一棵包含 个结点 ...

随机推荐

  1. Swift----安装,简单介绍

    安装: 眼下最新的稳定版是 Swift 0.94.1 1.下载:wget http://swiftlang.org/packages/swift-0.94.1.tar.gz 2.解压:tar xfz ...

  2. 王立平--Http中Get() 与 Post()的差别?

    Http协议是基于TCP协议的,而TCP协议是一种有连接.可靠的传输协议.假设丢失的话,会重传.所以这种话,就 不会有数据的丢失了. 而Http协议有三种方法.Get,Post,Head方法.可是用的 ...

  3. 使用美橙主机建站(jsp+mysql+tomcat建站)

    1.注冊美橙互联账号:http://www.cndns.com/ 2.选择橙云主机: 3.选择你须要的主机类型. 3.能够随时与客服进行沟通.购买完毕后登陆 管理中心 4.点击左边 主机类管理--&g ...

  4. Linux中修改系统时间

    #date //显示当前日期 #date -s //设置当前时间,只有root权限才能设置,其他只能查看. #date -s 20061010 //设置成20061010,这样会把具体时间设置成空00 ...

  5. sql server drop login failed

    https://stackoverflow.com/questions/37275/sql-query-for-logins https://www.mssqltips.com/sqlserverti ...

  6. 通过top 5等待事件查看sql语句

    设计的动态性能视图有:v$session_event,v$session,v$sqlarea,首先在v$session_event中可以找到event,然后通过其动态性能视图找到sid,可以在v$se ...

  7. js分享代码

    <<!DOCTYPE html><html><head> <title></title></head> <body& ...

  8. H3BPM表单设计器公式设计参考

    表单设计器公式设计参考 整体说明 Ø 公式以javascript方式解析,最终支持JS语法或计算方式: Ø 公式变量以数据项为主,以{}符号表示数据项,例如数据项A,表示为{A}:如果是子表中的数据项 ...

  9. 使用autofac在mvc5下依赖注入

    把遇到的问题汇总一下: 一.安装mvc5版本 命令:pm> Install-Package Autofac 结果安装的Autofac.Integration.Mvc(版本为4.0),所引用的依赖 ...

  10. POJ 1200 Hash

    我的hash从来没写对过........ (白学了快一年OI --原来连个hash都没写对过) 但是 但是 今天是一个值得纪念的日子. 看看标题 我竟然在写hash的题解. (好了好了 废话少说) 题 ...