bzoj2588: Spoj 10628. Count on a tree(树上第k大)(主席树)

  每个节点继承父节点的树,则答案为query(root[x]+root[y]-root[lca(x,y)]-root[fa[lca(x,y)]])

#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=100010;
struct poi{int size,lt,rt;}tree[maxn*20];
struct zs{int too,pre;}e[maxn<<1];
int n,m,x,y,z,sz,tot,N;
int d[maxn],f[maxn][20],last[maxn],root[maxn],v[maxn],b[maxn],num[maxn];
inline void read(int &k)
{int f=1;k=0;char c=getchar();while(c<'0'||c>'9')c=='-'&&(f=-1),c=getchar();while(c<='9'&&c>='0')k=k*10+c-'0',c=getchar();k*=f;
}
inline void add(int x,int y){e[++tot].too=y;e[tot].pre=last[x];last[x]=tot;}
void insert(int &x,int l,int r,int cx)
{tree[++sz]=tree[x];tree[sz].size++;x=sz;if(l==r)return;int mid=(l+r)>>1;if(cx<=mid)insert(tree[x].lt,l,mid,cx);else insert(tree[x].rt,mid+1,r,cx);
}
int query(int a,int b,int c,int d,int l,int r,int k)
{if(l==r)return l;int mid=(l+r)>>1;int t1=tree[a].lt,t2=tree[b].lt,t3=tree[c].lt,t4=tree[d].lt;int tmp=tree[t1].size+tree[t2].size-tree[t3].size-tree[t4].size;if(tmp>=k)return query(t1,t2,t3,t4,l,mid,k);return query(tree[a].rt,tree[b].rt,tree[c].rt,tree[d].rt,mid+1,r,k-tmp);
}
void dfs(int x,int fa)
{root[x]=root[fa];insert(root[x],1,N,v[x]);d[x]=d[fa]+1;f[x][0]=fa;for(int i=last[x];i;i=e[i].pre)if(e[i].too!=fa)dfs(e[i].too,x);
}
inline int lca(int x,int y)
{if(d[x]<d[y])swap(x,y);for(int i=19;i>=0;i--)if(d[f[x][i]]>=d[y])x=f[x][i];if(x==y)return x;for(int i=19;i>=0;i--)if(f[x][i]!=f[y][i])x=f[x][i],y=f[y][i];return f[x][0];
}
int main()
{read(n);read(m);for(int i=1;i<=n;i++)read(v[i]),b[i]=v[i];N=n;sort(b+1,b+1+N);N=unique(b+1,b+1+N)-b-1;for(int i=1;i<=n;i++)x=lower_bound(b+1,b+1+N,v[i])-b,num[x]=v[i],v[i]=x;for(int i=1;i<n;i++)read(x),read(y),add(x,y),add(y,x);dfs(1,0);for(int j=1;j<20;j++)for(int i=1;i<=n;i++)f[i][j]=f[f[i][j-1]][j-1];int lan=0;for(int i=1;i<=m;i++){read(x);read(y);read(z);x^=lan;int fq=lca(x,y);printf("%d",lan=num[query(root[x],root[y],root[fq],root[f[fq][0]],1,N,z)]);if(i!=m)puts("");}
}
View Code

 

转载于:https://www.cnblogs.com/Sakits/p/7593517.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/253318.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

图文详解YUV420数据格式

YUV格式有两大类&#xff1a;planar和packed。 对于planar的YUV格式&#xff0c;先连续存储所有像素点的Y&#xff0c;紧接着存储所有像素点的U&#xff0c;随后是所有像素点的V。 对于packed的YUV格式&#xff0c;每个像素点的Y,U,V是连续交*存储的。 YUV&#xff0c;分为三个…

USB通信接口介绍

1. 概述 Usb Universal Serial Bus全称通用串行总线&#xff0c;是一种支持热插拔的高速串行传输总线&#xff0c;使用差分信号来传输数据。 USB设备可以直接和host通信&#xff0c;或者通过hub和host通信。一个USB系统中仅有一个USB主机&#xff0c;设备包括功能设备和hub&…

关于java中BufferedReader的read()及readLine()方法的使用心得

BufferedReader的readLine()方法是阻塞式的, 如果到达流末尾, 就返回null, 但如果client的socket末经关闭就销毁, 则会产生IO异常. 正常的方法就是使用socket.close()关闭不需要的socket. 从一个有若干行的文件中依次读取各行&#xff0c;处理后输出&#xff0c;如果用以下方法…

HDCVI——一种创新性的高清视频传输方案

什么是HDCVI 2012年11月&#xff0c;大华技术股份有限公司发布了具有自主知识产权的同轴高清传输接口技术HDCVI。HDCVI技术是一种基于已有SYV75-3或SYV75-5同轴电缆的高清视频传输方法&#xff0c;能够在低成本和较低质量的同轴电缆上实现超长距离高清视频信号的可靠传输。相比…

typedef struct 用法

如果在c程序中我们写&#xff1a;    typedef struct     {    int num;    int age;    }aaa,bbb,ccc;    这算什么呢&#xff1f;    我个人观察编译器&#xff08;VC6&#xff09;的理解&#xff0c;这相当于    typedef struct     …

智能机器人品牌简介

随着科技的发展&#xff0c;硬件的计算速度和大数据支撑&#xff0c;越来越多的智能化设备和产品出现在我们的面前&#xff0c;为我们的生活带来更多便利。其中包括智能机器人&#xff0c;这种产品是有自己的“大脑”&#xff0c;可以接收人为指令&#xff0c;为人服务&#xf…

转 Java对日期Date类进行加减运算一二三

请移步&#xff0c;https://blog.csdn.net/hacker_lees/article/details/74351838 &#xff0c;感谢博主分享转载于:https://www.cnblogs.com/bestxyl/p/9790088.html

诞生之日 随笔

今天我诞生了&#xff0c;祝自己诞生日happy&#xff0c;happy&#xff0c;happy&#xff01; 转载于:https://www.cnblogs.com/xiaohuihui-/p/7594406.html

智能音箱 之 麦克风参数介绍

1. 定义 麦克风&#xff0c;学名为传声器&#xff0c;是将声音信号转换为电信号的能量转换器件&#xff1b;声—电转换。 与扬声器正好相反&#xff08;电—声转换&#xff09;&#xff0c;构成电声设备的两个终端&#xff0c;俗称咪头&#xff0c;麦克等。 是电声系统的入口&a…

大屏幕行业发展现状以及趋势深刻剖析

浏览数: 689 海康威视&#xff1a;叶志龙 中国投影网&#xff1a;大屏幕显示作为安防领域重要一环&#xff0c;而海康威视作为安防领域的佼佼者&#xff0c;请介绍海康威视大屏显示系统DLP/LCD这两大产品线&#xff1f;与行业同类产品相比&#xff0c;海康威视大屏拼接单元产品…

架构师是大忽悠吗?阿里技术大牛告诉你真相!

来源&#xff1a;阿里云 作者&#xff1a;林昊&#xff08;花名毕玄&#xff09;&#xff0c;阿里巴巴技术保障部研究员&#xff0c;曾任淘宝网平台架构部架构师。个人的研究方向主要为Java模块化、动态化系统的构建&#xff0c;以及高性能大型分布式Java系统构建&#xff0c;主…

动手动脑-Java重载

有以下例子&#xff1a; 例&#xff1a; Using overloaded methods public class MethodOverload { public static void main(String[] args) { System.out.println("The square of integer 7 is " square(7)); System.out.println("\nThe square of double 7.…

利用django框架,手把手教你搭建数据可视化系统(一)

如何使用django去构建数据可视化的 web,可视化的结果可以呈现在web上。 使用django的MTV模型搭建网站 基础铺垫—MTV模型 Created with Raphal 2.1.0Request服务器&#xff08;Djangoweb&#xff09;Response首先&#xff0c;要搞清楚我们去访问服务器&#xff0c;服务器返回信…

智能音箱 之 扬声器喇叭介绍

在全双工语音交互的系统中&#xff0c;功放的质量是非常重要的&#xff0c;因为AEC回声消除对信号失真 是非常敏感的。音频通路的整体谐波失真需要控制在5%以内。 对于整个系统的谐波失真来说&#xff0c;扬声器是最关键的因素&#xff0c;其次是功放&#xff0c;麦克风的很小…

关于拓扑排序的问题-P3116 [USACO15JAN]会议时间Meeting Time

https://www.luogu.org/problem/show?pid3116 这道题目很水啊&#xff0c;但是我没有1A&#xff0c;而且wa了好多&#xff1b; 题目意思我就不讲了&#xff1b; 反正就是一个拓扑序dp&#xff1b; 但是这道题目规定了起点是1&#xff1b; 所以我一开始直接把1放进队列里然…

HD-SDI DVR发展与应用剖析

自2010年以来&#xff0c;视频监控已经进入“高清”监控时代&#xff1b;随着高清的发展&#xff0c;HD-SDI高清数字系统开始进入人们的视线&#xff0c;在大、小展会上均可以轻松找到“数字高清”的产品和解决方案。作为HD-SDI系统中编码、存储部分的HD-SDI高清数字硬盘录像机…

UML学习——类图(三)

1.类图 UML类图是用来描述类、接口、协作及它们之间的关系的图。用来显示系统中各个类的静态结构。 2.类图的组成元素 类图由以下六种元素组成&#xff1a;类&#xff0c;接口&#xff0c;泛化关系&#xff0c;关联关系&#xff0c;依赖关系&#xff0c;实现关系。 3.类图的绘制…

传锤子科技解散成都分公司 才搬迁一年罗永浩就顶不住了

雷帝网 乐天 10月16日报道今日有网友爆料&#xff0c;锤子科技解散成都分公司。有网友指出&#xff0c;爆料的人是锤子科技早期员工王前闯。网友爆料锤子成都研发中心解散网友爆料锤子成都研发中心解散2016年&#xff0c;锤子科技亏损4亿元&#xff0c;一直徘徊在破产的边缘&am…

智能音箱 之 功放与扬声器(喇叭)的匹配关系

1. 功放的概念   功率放大器简称功放&#xff0c;俗称 “扩音机”&#xff0c;是音响系统中最基本的设备&#xff0c;它的任务是把来自信号源&#xff08;专业音响系统中则是来自调音台&#xff09;的微弱电信号进行放大以驱动扬声器发出声音。 2. 功放的分类 功率放大器分…

前端性能优化 Web前端应该从哪些方面来优化网站?

作者&#xff1a;斯迪链接&#xff1a;https://www.zhihu.com/question/21658448/answer/18903129来源&#xff1a;知乎著作权归作者所有。商业转载请联系作者获得授权&#xff0c;非商业转载请注明出处。前端是庞大的&#xff0c;包括 HTML、 CSS、 Javascript、Image 、Flash…