问题 B: $e$

时间限制: 2 Sec  内存限制: 512 MB

题面


题面谢绝公开。

题解


话说一天考两个主席树这回事……

正解可以叫树上主席树??(脸哥说也叫主席树上树???)

对于树上的每一条链建主席树,支持链上查询前驱和后继。

对于所有的$p[i]$,他说怎么得到就按他说的做就好,然后求所有$p[i]$的$LCA$。

对于每个$p[i]$到$LCA$的链上查一次$r$的前驱和后继更新答案即可。

注意:参数不要传反、别一个特判把自己判掉、pre和nxt的代码不要粘贴,粘贴了不要忘记改掉内部递归函数……

(昨天下午大概帮3、4个人调这题代码???RP++)

#include<bits/stdc++.h>
#define rint register int
using namespace std;
const int N=,M=;
inline void read(int &A)
{
A=;int B=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')B=-;ch=getchar();}
while(ch>=''&&ch<=''){A=(A<<)+(A<<)+ch-'';ch=getchar();}
A=A*B;
}
int n,q,tp,ans,a[N],p[N];
int v[N<<],nxt[N<<],first[N<<],tot;
int root[N],ls[N<<],rs[N<<],val[N<<],cnt;
int dep[N],f[N][];
inline void build_line(int uu,int vv)
{
v[++tot]=vv,nxt[tot]=first[uu];
first[uu]=tot;return ;
}
inline void insert(int &k,int l,int r,int his,int dat)
{
k=++cnt;val[k]=val[his]+;
if(l==r)return ;
ls[k]=ls[his],rs[k]=rs[his];
int mid=(l+r)>>;
if(dat<=mid)insert(ls[k],l,mid,ls[his],dat);
else insert(rs[k],mid+,r,rs[his],dat);
}
inline int get_pre(int k1,int k2,int l,int r,int dat)
{
if(!(val[k2]-val[k1]))return ;
if(l==r)return l;int mid=(l+r)>>;
if(dat<=mid)return get_pre(ls[k1],ls[k2],l,mid,dat);
int lin=get_pre(rs[k1],rs[k2],mid+,r,dat);
if(!lin)return get_pre(ls[k1],ls[k2],l,mid,dat);
return lin;
}
inline int get_nxt(int k1,int k2,int l,int r,int dat)
{
if(!(val[k2]-val[k1]))return ;
if(l==r)return l;int mid=(l+r)>>;
if(dat>mid)return get_nxt(rs[k1],rs[k2],mid+,r,dat);
int lin=get_nxt(ls[k1],ls[k2],l,mid,dat);
if(!lin)return get_nxt(rs[k1],rs[k2],mid+,r,dat);
return lin;
}
inline void bfs()
{
queue <int> q;
q.push();dep[]=;
while(!q.empty())
{
int x=q.front();q.pop();
for(rint i=first[x];i;i=nxt[i])
{
int y=v[i];if(dep[y])continue;
dep[y]=dep[x]+;f[y][]=x;
for(rint i=;i<=;++i)
f[y][i]=f[f[y][i-]][i-];
q.push(y);
}
}
return ;
}
inline int get_lca(int x,int y)
{
if(dep[x]<dep[y])swap(x,y);
for(rint i=;i>=;--i)
if(dep[f[x][i]]>=dep[y])x=f[x][i];
if(x==y)return x;
for(rint i=;i>=;--i)
if(f[x][i]!=f[y][i])
x=f[x][i],y=f[y][i];
return f[x][];
}
inline void dfs_build(int x,int fa)
{
insert(root[x],,M,root[fa],a[x]);
for(rint i=first[x];i;i=nxt[i])
if(v[i]!=fa)dfs_build(v[i],x);
return ;
}
int main()
{
read(n),read(q),read(tp);
for(rint i=;i<=n;++i)read(a[i]);
for(rint i=,ST,EN;i<n;++i)
read(ST),read(EN),build_line(ST,EN),build_line(EN,ST);
dfs_build(,);bfs();
for(rint i=,r,k;i<=q;++i)
{
read(r),read(k);
for(rint j=,x;j<=k;++j)
read(x),p[j]=(x-+ans*tp)%n+;
int lca=p[];
for(rint j=;j<=k;++j)
lca=get_lca(lca,p[j]);
ans=0x7fffffff;
for(rint j=;j<=k;++j)
{
int pre=get_pre(root[f[lca][]],root[p[j]],,M,r);
int nxt=get_nxt(root[f[lca][]],root[p[j]],,M,r);
if(pre)ans=min(r-pre,ans);
if(nxt)ans=min(nxt-r,ans);
}
printf("%d\n",ans);
}
}

「题解」:$e$的更多相关文章

  1. 「题解」「美团 CodeM 资格赛」跳格子

    目录 「题解」「美团 CodeM 资格赛」跳格子 题目描述 考场思路 思路分析及正解代码 「题解」「美团 CodeM 资格赛」跳格子 今天真的考自闭了... \(T1\) 花了 \(2h\) 都没有搞 ...

  2. 「题解」「HNOI2013」切糕

    文章目录 「题解」「HNOI2013」切糕 题目描述 思路分析及代码 题目分析 题解及代码 「题解」「HNOI2013」切糕 题目描述 点这里 思路分析及代码 题目分析 这道题的题目可以说得上是史上最 ...

  3. 「题解」JOIOI 王国

    「题解」JOIOI 王国 题目描述 考场思考 正解 题目描述 点这里 考场思考 因为时间不太够了,直接一上来就着手暴力.但是本人太菜,居然暴力爆 000 ,然后当场自闭- 一气之下,发现对 60pts ...

  4. 「题解报告」 P3167 [CQOI2014]通配符匹配

    「题解报告」 P3167 [CQOI2014]通配符匹配 思路 *和?显然无法直接匹配,但是可以发现「通配符个数不超过 \(10\) 」,那么我们可以考虑分段匹配. 我们首先把原字符串分成多个以一个通 ...

  5. Linux 小知识翻译 - 「RAID」

    最近术语「RAID」变得比较有名.「RAID」是指将多个HDD组合起来使用,从而提高存储可靠性的一种技术. 那么,关于 RAID 中的 「RAID 0」「RAID 1」「RAID 5」等各种「RAID ...

  6. 正则表达式从入门到放弃「Java」

    正则表达式能做什么? 正则表达式可以用来搜索.编辑或处理文本. 「都懂它可以处理文本,可到底是怎么回事?」 正则表达式的定义 百度百科:正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特 ...

  7. 「题解」:[loj2763][JOI2013]现代豪宅

    问题 A: 现代豪宅 时间限制: 1 Sec  内存限制: 256 MB 题面 题目描述 (题目译自 $JOI 2013 Final T3$「現代的な屋敷」) 你在某个很大的豪宅里迷路了.这个豪宅由东 ...

  8. Scala 学习(10)之「集合 」

    数组 定长数组 Array:采用()访问,而不是[],下标从 0 开始. val array1 = new Array[String](5) //创建数组 println(array1) //返回数组 ...

  9. JavaScript OOP 之「创建对象」

    工厂模式 工厂模式是软件工程领域一种广为人知的设计模式,这种模式抽象了创建具体对象的过程.工厂模式虽然解决了创建多个相似对象的问题,但却没有解决对象识别的问题. function createPers ...

  10. Facebook 发布「流程」

    时不时就会在面试过程中碰到有候选人问 Facebook 是否采用 Scrum 之类的敏捷方法,偶尔也会有中国的朋友问及 Facebook 上线流程.我通常会简单说几句,然后说「如果你真感兴趣的话,去搜 ...

随机推荐

  1. IPv4 IPv6

    IP提供了一种best-effort,connection-less数据delivery服务. best-efforty意味着它不保证IP数据段会成功到达目的地.当error发生时,IP通常选择丢弃d ...

  2. drop,delete与truncate的区别

    drop直接删掉表 truncate删除表中数据,再插入时自增长id又从1开始 delete删除表中数据,可以加where字句. (1) DELETE语句执行删除的过程是每次从表中删除一行,并且同时将 ...

  3. windows下安装jenkins初级(1)

    这里是基于Windows系统下安装Jenkins 首先下载jenkins 下载地址:https://jenkins.io/download/ 选择所需要的系统 我这里选择Windows 开始安装 一直 ...

  4. python基础第9章 魔法方法、属性和迭代器(一)

    __getitem__和__setitem__: 这个方法返回与指定键想关联的值.对序列来说,键应该是0~n-1的整数,其中n为序列的长度.对映射来说,键可以是任何类型. class A : __ge ...

  5. vue中数据绑定遇到的问题

    <!-- 使用element中的表格组件,在编辑的时候传递每行的数据 --> <el-button size="small" type="success ...

  6. thinkphp 输入过滤

    永远不要相信客户端提交的数据,所以对于输入数据的过滤势在必行,我们建议: 开启令牌验证避免数据的重复提交: 使用自动验证和自动完成机制进行初步过滤: 使用系统提供的I函数获取用户输入数据: 对不同的应 ...

  7. Element-UI 的树列表实现单选

    1. Element-UI 的 el-tree 组件当设置了 show-checkbox 属性以后,默认是只能多选的,如果我们想要将其改选为单选,就要进行一些特殊的处理,首先看效果图. 2. 组件代码 ...

  8. hdu6606多校第四次04——线段树加速dp

    /* 首先想到二分答案,难点在于如何判断是否有K段,每段和<=mid 把问题转化成求最多有R段,最少有L段,每段的的和<=mid,如果 L<=K<=R 那么显然存在把这个序列分 ...

  9. mysql在win系统dos 安装版配置步骤详解

    1.准备工作 下载mysql的最新免安装版本mysql-noinstall-5.1.53-win32.zip,解压缩到相关目录,如:d:\ mysql-noinstall-5.1.53-win32.这 ...

  10. IDea 工具debug模式详细使用说明

    IDea 工具debug模式详细使用说明 IDEA中如何使用debug调试项目 一步一步详细教程 Debug用来追踪代码的运行流程,通常在程序运行过程中出现异常,启用Debug模式可以分析定位异常发生 ...