洛谷$P2824\ [HEOI2016/TJOI2016]$ 排序 线段树+二分
正解:线段树+二分
解题报告:
昂着题好神噢我$jio$得$QwQQQQQ$,,,
开始看到长得很像之前考试题的亚子,,,然后仔细康康发现不一样昂$kk$,就这里范围是$[1,n]$,而且每个数字只出现了一次,显然就不能用线段树维护每个数字的出现次数了$QAQ$
考虑先二分这个位置上的数字,然后把所有大于这个数字的赋值为1其他赋值为0,然后就直接按01排序,最后$check$这个位置是0还是1就成$QwQ$
$over$
#include<bits/stdc++.h>
using namespace std;
#define il inline
#define gc getchar()
#define ri register int
#define rc register char
#define rb register bool
#define rp(i,x,y) for(ri i=x;i<=y;++i)
#define my(i,x,y) for(ri i=x;i>=y;--i) const int N=1e5+,inf=1e9;
int n,m,q,a[N],st[N],l=inf,r,tr[N<<],tag[N<<],as;
struct node{int op,l,r;}nod[N]; il int read()
{
rc ch=gc;ri x=;rb y=;
while(ch!='-' && (ch>'' || ch<''))ch=gc;
if(ch=='-')ch=gc,y=;
while(ch>='' && ch<='')x=(x<<)+(x<<)+(ch^''),ch=gc;
return y?x:-x;
}
void build(ri nw,ri l,ri r)
{
if(l==r)return void(tr[nw]=st[l]);
ri mid=(l+r)>>;build(nw<<,l,mid);build(nw<<|,mid+,r);tr[nw]=tr[nw<<]+tr[nw<<|];
}
void pushdown(ri x,ri l,ri r)
{
if(tag[x]==-)return;
ri mid=(l+r)>>;tr[x<<]=tag[x]*(mid-l+);tr[x<<|]=tag[x]*(r-mid);tag[x<<]=tag[x<<|]=tag[x];tag[x]=-;
}
int query(ri nw,ri l,ri r,ri to_l,ri to_r)
{
if(to_l<=l && r<=to_r)return tr[nw];
ri mid=(l+r)>>,ret=;pushdown(nw,l,r);
if(mid>=to_l)ret+=query(nw<<,l,mid,to_l,to_r);
if(mid<to_r)ret+=query(nw<<|,mid+,r,to_l,to_r);
tr[nw]=tr[nw<<]+tr[nw<<|];
return ret;
}
void modify(ri nw,ri l,ri r,ri to_l,ri to_r,ri dat)
{
if(to_l>to_r)return;
if(to_l<=l && r<=to_r){tag[nw]=dat,tr[nw]=dat*(r-l+);return;}
ri mid=(l+r)>>;pushdown(nw,l,r);
if(mid>=to_l)modify(nw<<,l,mid,to_l,to_r,dat);
if(mid<to_r)modify(nw<<|,mid+,r,to_l,to_r,dat);
tr[nw]=tr[nw<<]+tr[nw<<|];
}
il bool check(ri d)
{
rp(i,,n)st[i]=a[i]>=d;
build(,,n);memset(tag,-,sizeof(tag));
rp(i,,m)
{
ri dat=query(,,n,nod[i].l,nod[i].r);
if(nod[i].op){modify(,,n,nod[i].l,nod[i].l+dat-,);modify(,,n,nod[i].l+dat,nod[i].r,);}
else{modify(,,n,nod[i].r-dat+,nod[i].r,);modify(,,n,nod[i].l,nod[i].r-dat,);}
}
return query(,,n,q,q);
} int main()
{
l=;r=n=read();m=read();memset(tag,-,sizeof(tag));
rp(i,,n)a[i]=read();rp(i,,m)nod[i]=(node){read(),read(),read()};q=read();
while(l<=r){ri mid=(l+r)>>;if(check(mid))l=mid+,as=mid;else r=mid-;}printf("%d\n",as);
return ;
}
洛谷$P2824\ [HEOI2016/TJOI2016]$ 排序 线段树+二分的更多相关文章
- [Luogu P2824] [HEOI2016/TJOI2016]排序 (线段树+二分答案)
题面 传送门:https://www.luogu.org/problemnew/show/P2824 Solution 这题极其巧妙. 首先,如果直接做m次排序,显然会T得起飞. 注意一点:我们只需要 ...
- [HEOI2016/TJOI2016]排序 线段树+二分
[HEOI2016/TJOI2016]排序 内存限制:256 MiB 时间限制:6000 ms 标准输入输出 题目类型:传统 评测方式:文本比较 题目描述 在2016年,佳媛姐姐喜欢上了数字序列.因而 ...
- Luogu P2824 [HEOI2016/TJOI2016]排序 线段树+脑子
只会两个$log$的$qwq$ 我们二分答案:设答案为$ans$,则我们把$a[i]<=ans$全部设成$0$,把$a[i]>ans$全部设成$1$,扔到线段树里,这样区间排序(升序)就是 ...
- day 1 晚上 P2824 [HEOI2016/TJOI2016]排序 线段树
#include<iostream> #include<cstdio> #include<cstdlib> #include<cmath> #inclu ...
- 洛谷 P2824 [HEOI2016/TJOI2016]排序 解题报告
P2824 [HEOI2016/TJOI2016]排序 题意: 有一个长度为\(n\)的1-n的排列\(m\)次操作 \((0,l,r)\)表示序列从\(l\)到\(r\)降序 \((1,l,r)\) ...
- 洛谷P4344 脑洞治疗仪 [SHOI2015] 线段树+二分答案/分块
!!!一道巨恶心的数据结构题,做完当场爆炸:) 首先,如果你用位运算的时候不小心<<打成>>了,你就可以像我一样陷入疯狂的死循环改半个小时 然后,如果你改出来之后忘记把陷入死循 ...
- 洛谷P2824 [HEOI2016/TJOI2016]排序(线段树)
传送门 这题的思路好清奇 因为只有一次查询,我们考虑二分这个值为多少 将原序列转化为一个$01$序列,如果原序列上的值大于$mid$则为$1$否则为$0$ 那么排序就可以用线段树优化,设该区间内$1$ ...
- 洛谷 P2824 [HEOI2016/TJOI2016]排序 (线段树合并)
(另外:题解中有一种思路很高妙而且看上去可以适用一些其他情况的离线方法) 线段树合并&复杂度的简单说明:https://blog.csdn.net/zawedx/article/details ...
- BZOJ4552:[TJOI2016&HEOI2016]排序(线段树,二分)
Description 在2016年,佳媛姐姐喜欢上了数字序列.因而他经常研究关于序列的一些奇奇怪怪的问题,现在他在研究一个难题,需要你来帮助他. 这个难题是这样子的:给出一个1到n的全排列,现在对这 ...
随机推荐
- Jmeter xpath处理器
- xml schema介绍
https://www.runoob.com/schema/schema-tutorial.html
- HZOJ 走格子
作者的正解: 对于100%的数据:行动可以分为两种: 1. 步行,花费一个单位的时间移动到4联通的相邻格子中去. 2. 使用传送门,指定一个方向的墙的前面的一个格子,步行至最近的一个墙的面前,使用传送 ...
- H3C SSH配置例子
- Websocket 简单对话:静态网页与pycharm对话
WebSocket websocket 是一种在单个Tcp连接上进行双全工通信的协议.websocket通信协议于2011年被IETF定为标准RFC6455,并 由RFc7936补充规范.WebSoc ...
- oracle总是使用索引的第一个列
如果索引是建立在多个列上, 只有在它的第一个列(leading column)被where子句引用时,优化器才会选择使用该索引. 译者按: 这也是一条简单而重要的规则. 见以下实例. SQL> ...
- echarts细节的修改(2):矩形数图,柱状图,折线图,雷达图等
1.矩形数图的配置,是直接拿饼图的配置 然后将type换成treemap. 修改类型 option.series.type = 'treemap'; 关闭面包屑导航 option.series.bre ...
- C#的类
一.String类 1.Length 字符的长度 string x = Console.ReadLine();int i = x.Length;// Length 是获取字符串的长度(从1开始数)Co ...
- H3C 帧中继基本概念
- HDU 1326
题意:给出一堆高度不一的砖头,现在使他们高度一样,问最少的移动次数,(每减少1就是移动一次) 思路:求出平均高度,然后模拟最后平均高度的数组,也就是说,每个数组对应每一个平均高度,也就是说比平均高度大 ...