http://codeforces.com/problemset/problem/484/E

题意

给定一个长度为n的数列,有m次询问,询问形如l r k

要你在区间[l,r]内选一个长度为k的区间,求区间最小数的最大值

整体二分啊。。。。O((n+m)log(n)log(值域))

对于一个询问,可以二分答案后(设二分出的答案为ans),将>=ans的数标记为1,<ans的数标记为0,然后求该询问区间内最长的连续且全为1的一段的长度x,如果x>=该询问要求的k则合法,否则不合法;

多次询问,发现可以整体二分

(如果带修改,貌似要可持久化一下整体二分中用的线段树?log^3??)

 #include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
struct Q
{
int type;
int l,r,x,num;
int pos,d;
}q[],qt1[],qt2[];
int n,m,ans[],len;
//二分答案后,将>=mid+1的数改为1,<mid+1的数改为0,判定区间最长连续1的长度是否>=k
namespace SegT
{
struct Info
{
int ld,rd,xd,sz;
bool a1;
}dat[];
Info operator+(const Info &a,const Info &b)
{
Info c;
c.a1=a.a1&&b.a1;c.sz=a.sz+b.sz;
c.ld=a.a1?a.sz+b.ld:a.ld;c.rd=b.a1?b.sz+a.rd:b.rd;
c.xd=max(a.rd+b.ld,max(a.xd,b.xd));
return c;
}
Info nn[]={{,,,,},{,,,,}};
int L,R,x;
#define mid (l+((r-l)>>1))
#define lc (num<<1)
#define rc (num<<1|1)
void build(int l,int r,int num)
{
if(l==r) {dat[num]=nn[];return;}
build(l,mid,lc);build(mid+,r,rc);
dat[num]=dat[lc]+dat[rc];
}
void _setx(int l,int r,int num)
{
if(l==r) {dat[num]=nn[x];return;}
if(L<=mid) _setx(l,mid,lc);
else _setx(mid+,r,rc);
dat[num]=dat[lc]+dat[rc];
}
Info _query(int l,int r,int num)
{
if(L<=l&&r<=R) return dat[num];
if(L<=mid&&mid<R) return _query(l,mid,lc)+_query(mid+,r,rc);
if(L<=mid) return _query(l,mid,lc);
if(mid<R) return _query(mid+,r,rc);
exit(-);
}
void setx(int l,int d)
{
L=l;x=d;_setx(,n,);
}
int query(int l,int r)
{
L=l;R=r;return _query(,n,).xd;
}
#undef mid
#undef lc
#undef rc
}
void solve(int lp,int rp,int l,int r)
{
if(lp>rp) return;
int i;
if(l==r)
{
for(i=lp;i<=rp;i++)
if(q[i].type==)
ans[q[i].num]=l;
return;
}
int mid=l+((r-l)>>),tlen1=,tlen2=;//qt1-->l,mid;qt2-->mid+1,r
for(i=lp;i<=rp;i++)
{
if(q[i].type==)
{
if(q[i].d>mid)
SegT::setx(q[i].pos,),qt2[++tlen2]=q[i];
else
qt1[++tlen1]=q[i];
}
else
{
if(SegT::query(q[i].l,q[i].r)>=q[i].x) qt2[++tlen2]=q[i];
else qt1[++tlen1]=q[i];
}
}
memcpy(q+lp,qt1+,sizeof(Q)*tlen1);
memcpy(q+lp+tlen1,qt2+,sizeof(Q)*tlen2);
solve(lp,lp+tlen1-,l,mid);
for(i=lp+tlen1;i<=rp;i++)
if(q[i].type==)
SegT::setx(q[i].pos,);
solve(lp+tlen1,rp,mid+,r);
}
int main()
{
int i,t;
scanf("%d",&n);
for(i=;i<=n;i++) scanf("%d",&t),q[++len].type=,q[len].pos=i,q[len].d=t;
scanf("%d",&m);
for(i=;i<=m;i++) q[++len].type=,scanf("%d%d%d",&q[len].l,&q[len].r,&q[len].x),q[len].num=i;
SegT::build(,n,);
solve(,len,,1e9);
for(i=;i<=m;i++) printf("%d\n",ans[i]);
return ;
}

貌似由于此题没有修改,可持久化线段树就是一个log了23333还是两个log,询问还是要二分答案的;可持久化线段树的做法大概是先离散化,然后将所有位置的值从小到大排序,建n棵线段树(当然共用了很多节点),第i棵线段树的第j位表示a[j]是(1)否(0)大于等于(所有n个数中)第i小的数(建法...应该是好建的,先不管了);查询就二分答案(设二分出的答案为ans,注意离散化),在第ans棵线段树上对应区间查询最长连续全为1段的长度,判合法;

Sign on Fence CodeForces - 484E的更多相关文章

  1. AC日记——Sign on Fence Codeforces 484e

    E. Sign on Fence time limit per test 4 seconds memory limit per test 256 megabytes input standard in ...

  2. Codeforces 484E Sign on Fence(是持久的段树+二分法)

    题目链接:Codeforces 484E Sign on Fence 题目大意:给定给一个序列,每一个位置有一个值,表示高度,如今有若干查询,每次查询l,r,w,表示在区间l,r中, 连续最长长度大于 ...

  3. CF&&CC百套计划4 Codeforces Round #276 (Div. 1) E. Sign on Fence

    http://codeforces.com/contest/484/problem/E 题意: 给出n个数,查询最大的在区间[l,r]内,长为w的子区间的最小值 第i棵线段树表示>=i的数 维护 ...

  4. CF 484E - Sign on Fence

    E. Sign on Fence time limit per test 4 seconds memory limit per test 256 megabytes input standard in ...

  5. Codeforces Round #276 (Div. 1) E. Sign on Fence 二分+主席树

    E. Sign on Fence   Bizon the Champion has recently finished painting his wood fence. The fence consi ...

  6. 【CF484E】Sign on Fence(主席树)

    [CF484E]Sign on Fence(主席树) 题面 懒得贴CF了,你们自己都找得到 洛谷 题解 这不就是[TJOI&HEOI 排序]那题的套路吗... 二分一个答案,把大于答案的都变成 ...

  7. CF484E Sign on Fence && [国家集训队]middle

    CF484E Sign on Fence #include<bits/stdc++.h> #define RG register #define IL inline #define _ 1 ...

  8. (困难) CF 484E Sign on Fence,整体二分+线段树

    Bizon the Champion has recently finished painting his wood fence. The fence consists of a sequence o ...

  9. Codeforces Round #276 (Div. 1) E. Sign on Fence (二分答案 主席树 区间合并)

    链接:http://codeforces.com/contest/484/problem/E 题意: 给你n个数的,每个数代表高度: 再给出m个询问,每次询问[l,r]区间内连续w个数的最大的最小值: ...

随机推荐

  1. influxDB系列(一)

    这个是github上面一个人总结的influxDB的操作手册,还不错:https://xtutu.gitbooks.io/influxdb-handbook/content/zeng.html 1. ...

  2. Win8系统如何关闭用户账户控制UAC

    按WIN+S,屏幕右侧出现搜索框,在搜索框中输入UAC,然后单击"更改用户账户控制设置"   然后把弹出的窗口改成"从不通知"就可以了  

  3. Deepin-安装laravel

    首先获取到composer.phar wget https://getcomposer.org/download/1.6.3/composer.phar 下载以后移动到目标区域 sudo mv com ...

  4. Android 自己定义View须要重写ondraw()等方法

    Android  自己定义View须要重写ondraw()等方法.这篇博客给大家说说自己定义View的写法,须要我们继承View,然后重写一些 方法,方法多多,看你须要什么方法 首先写一个自己定义的V ...

  5. 【C#】无损转换Image为Icon 【C#】组件发布:MessageTip,轻快型消息提示窗 【C#】给无窗口的进程发送消息 【手记】WebBrowser响应页面中的blank开新窗口及window.close关闭本窗体 【手记】调用Process.EnterDebugMode引发异常:并非所有引用的特权或组都分配给呼叫方 【C#】DataRowState演变备忘

    [C#]无损转换Image为Icon 如题,市面上常见的方法是: var handle = bmp.GetHicon(); //得到图标句柄 return Icon.FromHandle(handle ...

  6. 优化 html 标签 为何能用HTML/CSS解决的问题就不要使用JS?

    优化 html 标签 2018年05月11日 08:56:24 阅读数:19 有些人写页面会走向一个极端,几乎页面所有的标签都用div,究其原因,用div有很多好处,一个是div没有默认样式,不会有m ...

  7. 云上领跑,快人一步:华为云抢先发布Redis5.0

    12月17日,华为云在DCS2.0的基础上,快人一步,抢先推出了新的Redis 5.0产品,这是一个崭新的突破.目前国内在缓存领域的发展普遍停留在Redis4.0阶段,华为云率先发布了Redis5.0 ...

  8. 网易新闻client(高仿)

    近期整理了下自己曾经做过的项目,决定分享出来.本篇所展示的是仿网易新闻client,服务端是在新浪SAE部署着的.所以大家下载后,可直接在手机上看到效果.接下来看效果图: watermark/2/te ...

  9. 暴走吧!Snapdragon SDK开发速成指南

    (文/Aurora J) Qualcomm的Snapdragon处理器.它快如闪电.效率极高.擅长挑战多任务极限,而且拥有攻城狮们梦寐以求的无限潜能.它能确保您的手机集4G LTE.极速体验.长久续航 ...

  10. 创建javaScript 对象

    创建新实例person 并向其添加四个属性: person=new Object(); person.firstname="Bill"; person.lastname=" ...