题目

在2016年,佳媛姐姐喜欢上了数字序列。因而他经常研究关于序列的一些奇奇怪怪的问题,现在他在研究一个难题,需要你来帮助他。这个难题是这样子的:给出一个1到n的全排列,现在对这个全排列序列进行m次局部排序,排序分为两种:1:(0,l,r)表示将区间[l,r]的数字升序排序2:(1,l,r)表示将区间[l,r]的数字降序排序最后询问第q 位置上的数字。

分析

二分答案,

把二分出的ans与原序列比较,小于ans的数改为-1,大于ans的数改为1。

对于输入的每一个修改,用线段树来处理。

最后求出\(q\)位上的数是-1还是1,然后接着二分。

#include <cmath>
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <queue>
const int maxlongint=2147483647;
const int mo=1000000007;
const int N=100005;
using namespace std;
int a[N],n,m,re[N][4],k,ans,lazy[N*5],_0[N*5],_1[N*5];
int down(int v,int mid,int l,int r)
{
if(lazy[v]==-1)
{
lazy[v*2+1]=lazy[v*2]=lazy[v];
_0[v*2]=mid-l+1;
_0[v*2+1]=r-(mid+1)+1;
_1[v*2]=0;
_1[v*2+1]=0;
}
if(lazy[v]==1)
{
lazy[v*2+1]=lazy[v*2]=lazy[v];
_1[v*2]=mid-l+1;
_1[v*2+1]=r-(mid+1)+1;
_0[v*2]=0;
_0[v*2+1]=0;
}
lazy[v]=0;
}
int put(int v,int l,int r,int x,int y)
{
if(l==r)
{
if(y==-1)
_0[v]=1;
else _1[v]=1;
return 0;
}
int mid=(l+r)/2;
if(x<=mid)
put(v*2,l,mid,x,y);
else
put(v*2+1,mid+1,r,x,y);
_0[v]=_0[v*2]+_0[v*2+1];
_1[v]=_1[v*2]+_1[v*2+1];
}
int get(int v,int l,int r,int x,int y)
{
if(l==x && r==y)
{
return _1[v];
}
int mid=(l+r)/2;
down(v,mid,l,r);
int o;
if(y<=mid)
o=get(v*2,l,mid,x,y);
else
if(x>mid)
o=get(v*2+1,mid+1,r,x,y);
else
o=get(v*2,l,mid,x,mid)+get(v*2+1,mid+1,r,mid+1,y);
_0[v]=_0[v*2]+_0[v*2+1];
_1[v]=_1[v*2]+_1[v*2+1];
return o;
}
int change(int v,int l,int r,int x,int y,int value)
{
if(y<x) return 0;
int mid=(l+r)/2;
if(l==x && r==y)
{
lazy[v]=value;
if(value<0)
{
_0[v]=r-l+1;
_1[v]=0;
}
else
{
_1[v]=r-l+1;
_0[v]=0;
}
return 0;
}
down(v,mid,l,r);
if(y<=mid)
change(v*2,l,mid,x,y,value);
else
if(x>mid)
change(v*2+1,mid+1,r,x,y,value);
else
change(v*2,l,mid,x,mid,value),change(v*2+1,mid+1,r,mid+1,y,value);
_0[v]=_0[v*2]+_0[v*2+1];
_1[v]=_1[v*2]+_1[v*2+1];
}
int find(int v,int l,int r,int x)
{
if(l==r)
{
return _0[v];
}
int mid=(l+r)/2;
down(v,mid,l,r);
int o;
if(x<=mid)
o=find(v*2,l,mid,x);
else
o=find(v*2+1,mid+1,r,x);
_0[v]=_0[v*2]+_0[v*2+1];
_1[v]=_1[v*2]+_1[v*2+1];
return o;
}
bool check(int x)
{
memset(lazy,0,sizeof(lazy));
memset(_0,0,sizeof(_0));
memset(_1,0,sizeof(_1));
for(int i=1;i<=n;i++)
{
int g=a[i]<=x?-1:1;
put(1,1,n,i,g);
}
for(int i=1;i<=m;i++)
{
int p1=get(1,1,n,re[i][2],re[i][3]);
if(!re[i][1])
{
change(1,1,n,re[i][2],re[i][3]-p1,-1);
change(1,1,n,re[i][3]-p1+1,re[i][3],1);
}
else
{
change(1,1,n,re[i][2],re[i][2]+p1-1,1);
change(1,1,n,re[i][2]+p1,re[i][3],-1);
}
}
if(find(1,1,n,k))
return true;
else return false;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
{
scanf("%d",&a[i]);
}
for(int i=1;i<=m;i++)
{
scanf("%d%d%d",&re[i][1],&re[i][2],&re[i][3]);
}
scanf("%d",&k);
int l=1,r=n;
while(l<r)
{
int mid=(l+r)/2;
if(check(mid))
{
r=mid;
}
else
{
l=mid+1;
}
}
printf("%d",l);
}

【bzoj4552】【Tjoi2016&Heoi2016】【NOIP2016模拟7.12】排序的更多相关文章

  1. bzoj千题计划128:bzoj4552: [Tjoi2016&Heoi2016]排序

    http://www.lydsy.com/JudgeOnline/problem.php?id=4552 二分答案 把>=mid 的数看做1,<mid 的数看做0 这样升序.降序排列相当于 ...

  2. 【bzoj 4554】【Tjoi2016&Heoi2016】【NOIP2016模拟7.12】游戏

    题目 分析 当没有石头的时候,就用二分图匹配来做. 但现在加入了石头, 所以,求出每行和每列联通快的个数,如果有一块平地,包括在某个行联通块以及某个列联通块中,连边. //无聊打了网络流,匈牙利也可以 ...

  3. [BZOJ4552][TJOI2016&&HEOI2016]排序(二分答案+线段树/线段树分裂与合并)

    解法一:二分答案+线段树 首先我们知道,对于一个01序列排序,用线段树维护的话可以做到单次排序复杂度仅为log级别. 这道题只有一个询问,所以离线没有意义,而一个询问让我们很自然的想到二分答案.先二分 ...

  4. BZOJ4552 [Tjoi2016&Heoi2016]排序 【二分 + 线段树】

    题目链接 BZOJ4552 题解 之前去雅礼培训做过一道题,\(O(nlogn)\)维护区间排序并能在线查询 可惜我至今不能get 但这道题有着\(O(nlog^2n)\)的离线算法 我们看到询问只有 ...

  5. [bzoj4552][Tjoi2016][Heoi2016]排序

    Description 给出一个$1$到$n$的全排列,现在对这个全排列序列进行$m$次局部排序,排序分为$2$种: $1.(0,l,r)$表示将区间$[l,r]$的数字升序排序; $2.(1,l,r ...

  6. BZOJ4552: [Tjoi2016&Heoi2016]排序

    Description 在2016年,佳媛姐姐喜欢上了数字序列.因而他经常研究关于序列的一些奇奇怪怪的问题,现在他在研究一个难题 ,需要你来帮助他.这个难题是这样子的:给出一个1到n的全排列,现在对这 ...

  7. [bzoj4552][Tjoi2016&Heoi2016]排序-二分+线段树

    Brief Description DZY有一个数列a[1..n],它是1∼n这n个正整数的一个排列. 现在他想支持两种操作: 0, l, r: 将a[l..r]原地升序排序. 1, l, r: 将a ...

  8. BZOJ4552:[TJOI2016&HEOI2016]排序(线段树,二分)

    Description 在2016年,佳媛姐姐喜欢上了数字序列.因而他经常研究关于序列的一些奇奇怪怪的问题,现在他在研究一个难题,需要你来帮助他. 这个难题是这样子的:给出一个1到n的全排列,现在对这 ...

  9. 2018.08.01 BZOJ4552: [Tjoi2016&Heoi2016]排序(二分+线段树)

    传送门 线段树简单题. 二分答案+线段树排序. 实际上就是二分答案mid" role="presentation" style="position: relat ...

随机推荐

  1. Java ——接口

    本节重点思维导图 定义: public interface Traffic { public static final int sits = 4; public abstract void run() ...

  2. 【EWM系列】SAP EWM凭证对象表概览

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[EWM系列]SAP EWM凭证对象表概览   ...

  3. 【Python】我的第一个豆瓣短评爬虫

    写在开头 豆瓣上有着大量的影视剧的评论,所以说,要是想要实现对广大人民群众的观点的分析,对一部片子的理解,综合来看大家的评论是很有必要的.而短评作为短小精干的快速评论入口,是值得一谈的. 所以先要实现 ...

  4. Chapter02 第四节 函数

    2.4 函数 2.4.1 有返回值的函数 函数定义.函数原型.函数调用 函数定义即定义一个函数:形如 :double sqrt(double x){····} 函数调用即调用这个函数,形如 :doub ...

  5. 全新一台node节点加入到集群中

    目录 前言 对新节点做解析 方法一 hosts 文件解析 方法二 bind 解析 测试 分发密钥对 推送 CA 证书 flanneld 部署 推送flanneld二进制命令 推送flanneld秘钥 ...

  6. 工作笔记之:如何在eclipse安装CVS插件?找了很久的,自己总结一下

    (1)在主目录里“help”→Install New Software.....→The Eclipse Project Updates - http://download.eclipse.org/e ...

  7. [七月挑选]frp初使用

    title: frp初使用 先starfatedier/frp,再开工. 什么是frp? frp is a fast reverse proxy to help you expose a local ...

  8. Linux 解决E: Sub-process /usr/bin/dpkg returned an error code (1)错误

    在用apt-get安装软件时出现了类似于 install-info: No dir file specified; try --help for more information.dpkg: 处理 g ...

  9. 34. Find First and Last Position of Element in Sorted Array (JAVA)

    Given an array of integers nums sorted in ascending order, find the starting and ending position of ...

  10. vps(windows2003)安全设置参考

    一.禁止默认共享 建立一个记事本,填上以下代码.保存为 “删除默认共享.bat”并加到启动项目中 net share c$ /del net share d$ /del net share e$ /d ...