[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同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.«天天爱跑步»是一个养成类游戏,需要玩家每天按时上线,完成打卡任务. 这个游戏的地图可以看作一一棵包含 个结点 ...
随机推荐
- 进入全屏 nodejs+express+mysql实现restful风格的增删改查示例
首先,放上项目github地址:https://github.com/codethereforam/express-mysql-demo 一.前言 之前学的java,一直用的ssm框架写后台.前段时间 ...
- Python面向切面编程-语法层面和functools模块
1,Python语法层面对面向切面编程的支持(方法名装饰后改变为log) __author__ = 'Administrator' import time def log(func): def wra ...
- Ralink5350开发环境搭建
一.安装虚拟机(Oracle VM VirtualBox 或 VMware Workstation) 二.在虚拟机中安装linux操作系统(当前使用的是Ubuntu1204桌面版) 三.配置linu ...
- struts1——静态ActionForm与动态ActionForm
在struts1中,我们能够使用ActionForm来获取从client端提交上来的数据.并通过action配置中的name属性.将某个ActionForm配置到某次请求应答的Action中.作为本次 ...
- [SPOJ VLATTICE]Visible Lattice Points 数论 莫比乌斯反演
7001. Visible Lattice Points Problem code: VLATTICE Consider a N*N*N lattice. One corner is at (0,0, ...
- 文字录入无限制Undo,Redo的实现
这里只针对Edit的内容做一个简单的undo,redo功能: 原理就是,将新增字符和相关信息添加到undo列表,在undo动作时,取记录信息,并在edit中删除新增的字符,然后将此动作添加到redo列 ...
- poj--3624--Charm Bracelet(动态规划 水题)
Home Problem Status Contest Add Contest Statistic LOGOUT playboy307 UPDATE POJ - 3624 Charm Bracelet ...
- 【SCOI 2005】 骑士精神
[题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1085 [算法] IDA* [代码] #include<bits/stdc++. ...
- 2017-3-11 leetcode 217 219 228
ji那天好像是周六.....吃完饭意识到貌似今天要有比赛(有题解当然要做啦),跑回寝室发现周日才开始233333 =========================================== ...
- C - Insomnia cure
Problem description «One dragon. Two dragon. Three dragon», — the princess was counting. She had tro ...