BZOJ 3600 替罪羊树+线段树
思路:
当然是抄的黄学长的题解啦
//By SiriusRen
#include <cstdio>
#include <algorithm>
using namespace std;
#define N 500005
int n,m,rt,R,top,id[N],mx[N],pos[N];
double a[N];char ch[11];
struct data{
int l,r;
friend bool operator>(data x,data y){
if(a[x.l]>a[y.l])return 1;
if(a[x.l]==a[y.l]&&a[x.r]>a[y.r])return 1;
return 0;
}
friend bool operator==(data x,data y){
if(x.l!=y.l||x.r!=y.r)return 0;
return 1;
}
};
struct SCTree{
int cnt,size[N],ls[N],rs[N];data v[N];
void dfs(int k){
if(!k)return;
dfs(ls[k]);
id[++top]=k;
dfs(rs[k]);
}
void build(int &k,int l,int r,double lv,double rv){
if(l>r){k=0;return;}
double mv=(lv+rv)/2.0;
int mid=(l+r)>>1;k=id[mid];a[k]=mv;
build(ls[k],l,mid-1,lv,mv);
build(rs[k],mid+1,r,mv,rv);
size[k]=size[ls[k]]+size[rs[k]]+1;
}
void rebuild(int &k,double lv,double rv){
top=0;dfs(k);
build(k,1,top,lv,rv);
}
int insert(int &k,double lv,double rv,data val){
double mv=(lv+rv)/2.0;
if(!k){
k=++cnt;a[k]=mv;v[k]=val,size[k]=1;
return k;
}
int p;
if(val==v[k])return k;
else{
size[k]++;
if(val>v[k])p=insert(rs[k],mv,rv,val);
else p=insert(ls[k],lv,mv,val);
}
if(size[k]*0.666>max(size[ls[k]],size[rs[k]])){
if(R){
if(ls[k]==R)rebuild(ls[k],lv,mv);
else rebuild(rs[k],mv,rv);
R=0;
}
}
else R=k;
return p;
}
}sc;
void modify(int k,int l,int r,int v){
int mid=(l+r)>>1;
if(l==r){mx[k]=l;return;}
if(v<=mid)modify(k<<1,l,mid,v);
else modify(k<<1|1,mid+1,r,v);
int x=mx[k<<1],y=mx[k<<1|1];
mx[k]=a[pos[x]]>=a[pos[y]]?x:y;
}
int query(int k,int l,int r,int x,int y){
if(l>=x&&r<=y)return mx[k];
int mid=(l+r)>>1;
if(mid<x)return query(k<<1|1,mid+1,r,x,y);
else if(mid>=y)return query(k<<1,l,mid,x,y);
else{
int p1=query(k<<1|1,mid+1,r,x,y),p2=query(k<<1,l,mid,x,y);
return a[pos[p1]]>a[pos[p2]]?p1:p2;
}
}
int main(){
scanf("%d%d",&n,&m);
a[0]=-1;
sc.insert(rt,0,1,(data){0,0});
for(int i=1;i<=n;i++)pos[i]=1;
for(int i=1;i<=n;i++)modify(1,1,n,i);
int l,r,K;
for(int i=1;i<=m;i++){
scanf("%s%d%d",ch+1,&l,&r);
if(ch[1]=='C'){
scanf("%d",&K);
pos[K]=sc.insert(rt,0,1,(data){pos[l],pos[r]});
if(R)sc.rebuild(rt,0,1),R=0;
modify(1,1,n,K);
}
else printf("%d\n",query(1,1,n,l,r));
}
}
BZOJ 3600 替罪羊树+线段树的更多相关文章
- 「BZOJ3065」带插入区间第K小值 替罪羊树×线段树
题目描述 从前有\(n\)只跳蚤排成一行做早操,每只跳蚤都有自己的一个弹跳力\(a_i\).跳蚤国王看着这些跳蚤国欣欣向荣的情景,感到非常高兴.这时跳蚤国王决定理性愉悦一下,查询区间\(k\)小值.他 ...
- Bzoj 2752 高速公路 (期望,线段树)
Bzoj 2752 高速公路 (期望,线段树) 题目链接 这道题显然求边,因为题目是一条链,所以直接采用把边编上号.看成序列即可 \(1\)与\(2\)号点的边连得是. 编号为\(1\)的点.查询的时 ...
- 浅谈树套树(线段树套平衡树)&学习笔记
0XFF 前言 *如果本文有不好的地方,请在下方评论区提出,Qiuly感激不尽! 0X1F 这个东西有啥用? 树套树------线段树套平衡树,可以用于解决待修改区间\(K\)大的问题,当然也可以用 ...
- bzoj 3600 没有人的算术 - 替罪羊树 - 线段树
题目都是图片,就不给了,就给链接好了 由于bzoj比较慢,就先给[vjudge传送门] 有兴趣的可以去逛bzoj[bzoj传送门] 题目大意 有n个数a[1],a[2],...,a[n],它们开始都是 ...
- [BZOJ 1901] Dynamic Rankings 【树状数组套线段树 || 线段树套线段树】
题目链接:BZOJ - 1901 题目分析 树状数组套线段树或线段树套线段树都可以解决这道题. 第一层是区间,第二层是权值. 空间复杂度和时间复杂度均为 O(n log^2 n). 线段树比树状数组麻 ...
- BZOJ.3938.Robot(李超线段树)
BZOJ UOJ 以时间\(t\)为横坐标,位置\(p\)为纵坐标建坐标系,那每个机器人就是一条\(0\sim INF\)的折线. 用李超线段树维护最大最小值.对于折线分成若干条线段依次插入即可. 最 ...
- BZOJ.1558.[JSOI2009]等差数列(线段树 差分)
BZOJ 洛谷 首先可以把原序列\(A_i\)转化成差分序列\(B_i\)去做. 这样对于区间加一个等差数列\((l,r,a_0,d)\),就可以转化为\(B_{l-1}\)+=\(a_0\),\(B ...
- 「BZOJ3600」没有人的算术 替罪羊树+线段树
题目描述 过长--不想发图也不想发文字,所以就发链接吧-- 没有人的算术 题解 \(orz\)神题一枚 我们考虑如果插入的数不是数对,而是普通的数,这就是一道傻题了--直接线段树一顿乱上就可以了. 于 ...
- 【BZOJ3600】没有人的算术 - 替罪羊树+线段树
题意: 题解: Orz vfleaking……真·神题 做法大概是先把题意中定义的“数”都赋一个实数权值,用平衡树来维护整个从大到小排序过的序列,再用线段树查询最值: 这样做为什么是对的?考虑插入一个 ...
- 【BZOJ3600】没有人的算术(替罪羊树+线段树)
点此看题面 大致题意: 定义任意数对\(>0\),数对之间比大小先比第一位.后比第二位,一开始数列全为\(0\),要求你支持\(a_k=(a_x,a_y)\)和询问区间最大值所在位置两种操作. ...
随机推荐
- string 简单实现
namespace ss{ class string { friend ostream& operator <<(ostream&, const string&); ...
- Stop being a perfectionist
节选自 7 Things You Need To Stop Doing To Be More Productive, Backed By Science “We found that perfecti ...
- thinkphp项目上传到github,为什么缺少很多文件
thinkphp项目上传到github,为什么缺少很多文件 问题: 把tp5项目push到码云(类似github)上,为什么没有thinkphp这个核心库? 然后我看了下码云和github上,官方的t ...
- systemd服务管理---systemctl命令列出所有服务
1.列出系统所有服务 #systemctl list-units --all --type=service
- CentOS 6.5 下编译安装 Nginx 1.8.0
转自:https://i.cnblogs.com/EditPosts.aspx?postid=8303227&update=1 安装编译依赖的包 yum -y install gcc gcc- ...
- R学习小计
安装R扩展包:install.packages("FKF")http://www.douban.com/note/243004605/1.输入数据 l读入有分隔符数据:A<- ...
- Windows 10 Mobile 演示:插入耳机自动执行 APP
Windows Mobile 10 新特性:插入外部设备自动动作(如插入耳机执行 APP.打开小工具):另外可以找到最后一次使用设备地点和时间: http://www.tudou.com/progra ...
- 【算法】单源最短路径和任意两点最短路径总结(补增:SPFA)
[Bellman-Ford算法] [算法]Bellman-Ford算法(单源最短路径问题)(判断负圈) 结构: #define MAX_V 10000 #define MAX_E 50000 int ...
- PCL例程调试错误之缺少flann-config.cmake
编译环境和PCL版本为:win7-x64 + MSVC2013 + PCL1.8.0-win32-MSVC2013. 调试PCL官网例程Cluster Recognition and 6DOF Pos ...
- TypeError: Cannot use 'in' operator to search for 'length' in....
前台页面读取商品属性是字符串形式,数据库中存储商品属性是集合形式,前台数据存入数据库中数据格式会自动转,后台数据回显到前台数据格式需要手动转换,否则会报异常 错误信息提示: