题目来源:http://www.lydsy.com/JudgeOnline/problem.php?id=4719

镇楼图:

noip滚粗后、、订正的第一题。

题目大意:

有若干条路径在一棵树上,问每个点恰为多少条路径起点出发Ti长度处。

解题方略:

这题可以O(n)。。结果shy非常有趣地在考场上码80分暴力、结果还爆QAQ(这题,80分做法,比100分做法难吧。。)

考虑把询问分成不同的两个链。但是,如果有链的话,就不可避免要树剖。然而其实不必。利用DFS的性质,可以知道,在一个点打标记,可以影响到它的子树(相对地,也可以是所有父亲)。那么,我们考虑暴力,就是询问每个点x,子树里有多少个d[u]=d[x]+t[x]或d[v]-len[u,v]=d[x]-t[x],复杂度O(n*子树大小)。那么,这个只要一个桶就可以记录。求LCA只要tarjan离线就可以O(n+m),这里暂时把并查集的复杂度也看成常数倍。那么,有些人就会卡在子树的合并上。其实并不用合并。因为,一个点退出时,我们即知,其子树的操作都已经实施过(添加/删除),那么,我们只需在进入时算一遍Ans、退出时算一遍Ans,两者的差就是子树的贡献。

AC代码:

这里bzoj之前数据有漏导致WA了,事情咋那么多呢TAT。

 {$M 100000000,0,100000000}
type
Chitose=record
e:longint;
head :array[..]of longint;
next,node:array[..]of longint
end;
Chitoge=array[-..]of longint;
var
n,m,i,u,v:longint;
t,d,z,s,Ans:array[..]of longint;
p,q:Chitoge;
o,a:Chitose;
f,g:array[..]of Chitose; procedure ad(var x:Chitose;u,v:longint);
begin
with x do
begin
inc(e);
next[e]:=head[u];
head[u]:=e;
node[e]:=v
end
end; function fd(x:longint):longint;
begin if x<>z[x] then z[x]:=fd(z[x]); exit(z[x]) end; procedure sk(u:longint);
var i,v,w,x,y,c:longint;
begin
z[u]:=u;
i:=o.head[u];
while i<> do
begin
v:=o.node[i];
if d[v]= then begin d[v]:=d[u]+; sk(v); z[v]:=u end;
i:=o.next[i]
end;
i:=a.head[u];
while i<> do
begin
w:=a.node[i]>>;
if s[w]= then s[w]:=u
else begin v:=s[w];
c:=fd(v);
s[w]:=d[v]+d[u]-*d[c];
if odd(a.node[i]) then begin x:=v; y:=u end
else begin x:=u; y:=v end;
ad(f[],x,d[x]);
ad(f[],c,d[x]);
ad(g[],y,d[y]-s[w]);
ad(g[],c,d[y]-s[w]) end;
i:=a.next[i]
end
end; procedure __Claris(u:longint);
var i,v:longint;
begin
z[u]:=;
Ans[u]:=p[d[u]+t[u]]+q[d[u]-t[u]];
i:=f[].head[u]; while i<> do begin inc(p[f[].node[i]]); i:=f[].next[i] end;
i:=g[].head[u]; while i<> do begin inc(q[g[].node[i]]); i:=g[].next[i] end;
i:=o.head[u];
while i<> do
begin
v:=o.node[i];
if z[v]<> then __Claris(v);
i:=o.next[i]
end;
i:=f[].head[u]; while i<> do begin dec(p[f[].node[i]]); i:=f[].next[i] end; Ans[u]:=p[d[u]+t[u]]+q[d[u]-t[u]]-Ans[u];
i:=g[].head[u]; while i<> do begin dec(q[g[].node[i]]); i:=g[].next[i] end;
end; begin
read(n,m);
for i:= to n do
begin
read(u,v);
ad(o,u,v);
ad(o,v,u)
end;
for i:= to n do read(t[i]);
for i:= to m do
begin
read(u,v);
ad(a,u,i<<);
ad(a,v,i<<+)
end;
d[]:=;
sk();
__Claris();
write(Ans[]); for i:= to n do write(' ',Ans[i])
end.

[NOIP2016-day1-T2]天天爱跑步running_题解的更多相关文章

  1. [NOIP2016 DAY1 T2]天天爱跑步-[差分+线段树合并][解题报告]

    [NOIP2016 DAY1 T2]天天爱跑步 题面: B[NOIP2016 DAY1]天天爱跑步 时间限制 : - MS 空间限制 : 565536 KB 评测说明 : 2s Description ...

  2. Luogu P1600[NOIP2016]day1 T2天天爱跑步

    号称是noip2016最恶心的题 基本上用了一天来搞明白+给sy讲明白(可能还没讲明白 具体思路是真的不想写了(快吐了 如果要看,参见洛谷P1600 天天爱跑步--题解 虽然这样不好但我真的不想写了 ...

  3. NOIP2016 DAY1 T2天天爱跑步

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

  4. NOIP2016 Day1 T2 天天爱跑步(树上差分,LCA)

    原文链接 原题链接 题目描述 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.<天天爱跑步>是一个养成类游戏,需要玩家每天按时上线,完成打卡任务. 这个游戏 ...

  5. 【NOIP2016】DAY1 T2 天天爱跑步

    [NOIP2016]DAY1 T2 天天爱跑步 Description 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.?天天爱跑步?是一个养成类游戏,需要玩家每天按时 ...

  6. 【NOIP 2016】Day1 T2 天天爱跑步

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

  7. 【NOIP2016 Day1 T2】天天爱跑步

    题目传送门:https://www.luogu.org/problemnew/show/P1600 感觉这两天在处理边界问题上有点神志不清......为了从80的暴力变成100,花了整整一个下午+一个 ...

  8. [NOIp2016提高组]天天爱跑步

    题目大意: 有一棵n个点的树,每个点上有一个摄像头会在第w[i]秒拍照. 有m个人再树上跑,第i个人沿着s[i]到t[i]的路径跑,每秒钟跑一条边. 跑到t[i]的下一秒,人就会消失. 问每个摄像头会 ...

  9. P1600 [NOIP2016 提高组] 天天爱跑步 (树上差分)

    对于一条路径,s-t,位于该路径上的观察员能观察到运动员当且仅当以下两种情况成立:(d[ ]表示节点深度) 1.观察员x在s-lca(s,t)上时,满足d[s]=d[x]+w[x]就能观察到,所以我们 ...

随机推荐

  1. SAM4E单片机之旅——19、CAN间通信

    CAN协议具有良好的可靠性,在工业中应用广泛.这次就先熟悉CAN的基本功能. 开发板有两个CAN,每个CAN有8个信箱.这次内容是从CAN0的信箱0发送数据到CAN1的信箱0. 除本次使用的功能外,C ...

  2. 单点登录系统(SSO)之CAS(中央认证服务)

    SSO(Single Sign On)单点登录系统,是在多个系统中值要求只要登录一次,就可以用已登录的身份访问多个系统,去掉了每次访问不同的系统都要重新登录的弊端. CAS(中央/集中认证服务):Th ...

  3. 浅谈Python时间模块

    浅谈Python时间模块 今天简单总结了一下Python处理时间和日期方面的模块,主要就是datetime.time.calendar三个模块的使用.希望这篇文章对于学习Python的朋友们有所帮助 ...

  4. webstorm 注册码

    User Name: EMBRACE License Key: ===== LICENSE BEGIN ===== 24718-12042010 00001h6wzKLpfo3gmjJ8xoTPw5m ...

  5. C语言杂谈(一)scanf()、scanf_s()与错误 C4996

    错误 C4996 初学C语言时,第一个接触到的I/O函数便是scanf()了.但在高版本的 Visual Studio (包括但不限于2015.2013.2012)编译代码时,却会出现意想不到的错误. ...

  6. zoj 3229 Shoot the Bullet(无源汇上下界最大流)

    题目:Shoot the Bullet 收藏:http://www.tuicool.com/articles/QRr2Qb 把每一天看成一个点,每个女孩也看成一个点,增加源和汇s.t,源向每一天连上[ ...

  7. FZU Problem 2150 Fire Game

    Problem 2150 Fire Game Accept: 145    Submit: 542 Time Limit: 1000 mSec    Memory Limit : 32768 KB P ...

  8. UWP 矢量字体图标(iconfont)使用

    本文使用 阿里巴巴开源字体: 选择矢量字体图标: 查看或编辑 Unicode编码 或字体名称 下载到本地,添加到uwp项目 代码中写法 Text:Unicode编码 FontFamily:文件路径#字 ...

  9. WCF MSMQ消息队列与离线操作

    消息队列类型 公共队列:整个网络中的节点都可以访问到 专用队列:本地计算机,知道路径者可以访问 管理队列:包含确认在给定“消息队列”网络中的发送的消息回执的消息 相应队列:返回给发送程序的相应信息

  10. web前端笔试题总结

    em和rem的区别: 浏览器的默认字体高度是16px,1em=16px:大小可以自己设置调整,并且默认集成父级容器中文本的大小. rem是CSS3中新增的属性,默认情况下是文本尺寸的大小,不同的是它集 ...