[jzoj]5257.小X的佛光
Link
https://jzoj.net/senior/#main/show/5257
Problem

Solution
5~90分
我们可以根据特殊性质搞
如果数据小,直接暴力在树上面模拟一次
如果满足性质1,就是第i条边连i和i+1地,那么就成了一条链,答案是可以按照数学方法计算出来的
如果满足性质2,就是A=C,那么就是A~B的长度,可以预处理快速求出来
这些分数,感谢出题人的馈赠
100分
其实我们可以画个图,粗略的画个图,看看答案是什么

显然,根据这个图,我们就知道,答案其实就是BX这条线段的长度
怎么求?我们可以用最简单的容斥原理

加一是因为X这个点之后要div2,所以应该得被计算2次
我们发现,求AB,CB,AC的方法,都是求他们到lca的长度
所以,我们可以用倍增,对他们做lca,并且记录路径长度
我们一次递归,预处理出,每个点的深度。
在递归中,顺便预处理f数组
其中f[i,j]表示第i个节点,在他上面第2j个节点是什么。
我们先把深度大的点,用倍增,弄成和另外一个节点一样的深度,这个和下面的方法类似
然后同时倍增。
其实就是找一个最大的j,满足f[a,j]不等于f[b,j],一直弄,最后就成了lca的两个儿子。
加法随便弄一下就行了。
其他两个求法类似,不在赘述了。
时间复杂度:O(3n)(n表示点数)
Code
{$inline on}
var
n,m,i,j,x,y,z,tot:longint;
f:array[..,..] of longint;
pre,l,d:array[..] of longint;
dis,shen:array[..] of longint;
procedure insert(x,y:longint); inline;
begin
inc(tot);
d[tot]:=y;
pre[tot]:=l[x];
l[x]:=tot;
end;
procedure dg(now,k,q:longint); inline;
var
s:longint;
begin
shen[now]:=k;
f[now,]:=q;
s:=l[now];
while s<> do
begin
if dis[d[s]]= then
begin
dis[d[s]]:=;
dg(d[s],k+,now);
end;
s:=pre[s];
end;
end;
function yes(x,y:longint):longint; inline;
var
ans,k:longint;
begin
ans:=;
if shen[x]>shen[y] then
begin
while shen[x]>shen[y] do
begin
for k:= downto do
if shen[f[x,k]]>=shen[y] then
break;
x:=f[x,k];
ans:=ans+ shl k;
end;
end;
if shen[x]<shen[y] then
begin
while shen[x]<shen[y] do
begin
for k:= downto do
if shen[f[y,k]]>=shen[x] then
break;
y:=f[y,k];
ans:=ans+ shl k;
end;
end;
while x<>y do
begin
for k:= downto do
if (f[x,k]<>f[y,k]) and (f[x,k]<>) and (f[y,k]<>) then
break;
x:=f[x,k];
y:=f[y,k];
ans:=ans+ shl (k+);
end;
exit(ans);
end;
begin
readln(n,m,x);
for i:= to n- do
begin
readln(x,y);
insert(x,y);
insert(y,x);
end;
dis[]:=;
shen[]:=-maxlongint;
dg(,,);
for j:= to do
for i:= to n do
f[i,j]:=f[f[i,j-],j-];
while m> do
begin
readln(x,y,z);
writeln((yes(x,y)+yes(y,z)-yes(x,z)+) shr );
dec(m);
end;
end.
[jzoj]5257.小X的佛光的更多相关文章
- JZOJ 5257. 小X的佛光 (Standard IO)
5257. 小X的佛光 (Standard IO) Time Limits: 2000 ms Memory Limits: 524288 KB Description Input Output Sam ...
- JZOJ.5257【NOIP2017模拟8.11】小X的佛光
Description
- 计蒜客NOIP模拟赛4 D1T3 小X的佛光
小 X 是远近闻名的学佛,平日里最喜欢做的事就是蒸发学水. 小 X 所在的城市 X 城是一个含有 N 个节点的无向图,同时,由于 X 国是一个发展中国家,为了节约城市建设的经费,X 国首相在建造 X ...
- 常州模拟赛d2t3 小X的佛光
平日里最喜欢做的事就是蒸发学水.[题目描述]小 X 所在的城市 X 城是一个含有 N 个节点的无向图,同时,由于 X 国是一个发展中国家,为了节约城市建设的经费,X 国首相在建造 X 城时只建造 N ...
- [JZOJ] 5935. 小凯学数学
由Noip2018初赛的知识得,a|b + a&b = a+b 设计一个区间dp,设\(f[l][r][x]\)表示区间\([l,r]\)能否构成\(x\),数据不大,转移暴力枚举 复杂度\( ...
- 计蒜客NOIP2017提高组模拟赛(四)day1
T1:小X的质数 小 X 是一位热爱数学的男孩子,在茫茫的数字中,他对质数更有一种独特的情感.小 X 认为,质数是一切自然数起源的地方. 在小 X 的认知里,质数是除了本身和 1 以外,没有其他因数的 ...
- JZOJ 5777. 【NOIP2008模拟】小x玩游戏
5777. [NOIP2008模拟]小x玩游戏 (File IO): input:game.in output:game.out Time Limits: 1000 ms Memory Limits ...
- JZOJ 5793. 【NOIP2008模拟】小S练跑步
5793. [NOIP2008模拟]小S练跑步 (File IO): input:run.in output:run.out Time Limits: 2000 ms Memory Limits: ...
- JZOJ 5776. 【NOIP2008模拟】小x游世界树
5776. [NOIP2008模拟]小x游世界树 (File IO): input:yggdrasil.in output:yggdrasil.out Time Limits: 1500 ms Me ...
随机推荐
- Sql Server并发和事务
锁的作用范围通常在事务中,事务是建立在并发模式下. 从SQL Server 2005开始,加入了一种新的并发模式-----乐观并发.不管使用哪种并发模式,如果多个会话同时修改相同的数据,都会产生资源争 ...
- Android之Error: 'L' is not a valid file-based resource name character解决办法
1.问题 Error:Execution failed for task ':mergeBYODReleaseResources'.> /home/chenyu/Android_dev/sang ...
- react native初始化项目
打开命令行窗口,进入我们想要创建项目的父目录,输入命令: npm install -g yarn react-native-cli react-native init 项目名 进入新建的项目目录,执行 ...
- mysql时间延时注入案例
通过Burpsuite结合sqlmap发现如下接口存在时间盲注
- Flink--Table和DataStream和DataSet的集成
将DataStream或DataSet转换为表格 在上面的例子讲解中,直接使用的是:registerTableSource注册表 对于flink来说,还有更灵活的方式:比如直接注册DataStream ...
- Cookies 和 Session的区别
1.cookie 是一种发送到客户浏览器的文本串句柄,并保存在客户机硬盘上,可以用来在某个WEB站点会话间持久的保持数据. 2.session其实指的就是访问者从到达某个特定主页到离开为止的那段时间. ...
- BZOJ3944 Sum 数论 杜教筛
原文链接http://www.cnblogs.com/zhouzhendong/p/8671759.html 题目传送门 - BZOJ3944 题意 多组数据(组数<=10). 每组数据一个正整 ...
- BZOJ1096 [ZJOI2007]仓库建设 动态规划 斜率优化
原文链接http://www.cnblogs.com/zhouzhendong/p/8696410.html 题目传送门 - BZOJ1096 题意 给定两个序列$a,b,X$,现在划分$a$序列. ...
- Vijos1982 NOIP2015Day2T2 子串 substring 动态规划
子串 (substring.cpp/c/pas) 题目链接 [问题描述]有两个仅包含小写英文字母的字符串 A 和 B.现在要从字符串 A 中取出 k 个 互不重叠 的非空子串,然后把这 k 个子串按照 ...
- python必看经典书籍:笨办法学python
书评: 感谢作者和译者,很好的手把手的一个新手编程体验书,消除编程物质恐惧感,在线看的liam huang翻译的版,不确定看的是第几版,有一些加分题没有做,第五十题黑手党外星人飞船做起来有点压力,准备 ...