别人家的题解

#include<bits/stdc++.h>
#define N 200005
#define M (l+r>>1)
#define P (k<<1)
#define S (k<<1|1)
#define K l,r,k
#define L l,M,P
#define R M+1,r,S
#define Z \
int l=0,int r=n-1,int k=1
using namespace std;
int n,z,d;
typedef int seg[N<<2];
seg s[2],t[2],e;
void apply(int i,int d,Z){
	s[i][k]=d;
	t[i][k]=d+l;
	e[k]=d+t[i^1][k];
}
void devolve(Z){
	for(int i=0;i!=2;++i)
		if(s[i][k]!=INT_MIN){
			apply(i,s[i][k],L);
			apply(i,s[i][k],R);
			s[i][k]=INT_MIN;
		}
}
void update(int k){
	for(int i=0;i!=2;++i)
		t[i][k]=min(
		t[i][P],t[i][S]);
	e[k]=min(e[P],e[S]);
}
void change(
int i,int d,int s,int t,Z){
	if(s==l&&t==r)
		apply(i,d,K);
	else{
		devolve(K);
		if(t<=M)
			change(i,d,s,t,L);
		else if(s>M)
			change(i,d,s,t,R);
		else{
			change(i,d,s,M,L);
			change(i,d,M+1,t,R);
		}
		update(k);
	}
}
int query(int s,int t,Z){
	static int d;
	return s==l&&t==r
	&&e[k]>z?-1:l==r?l
	:(devolve(K),
	t<=M?query(s,t,L)
	:s>M?query(s,t,R)
	:~(d=query(s,M,L))
	?d:query(M+1,t,R));
}
typedef int ds[N];
ds f,a,q,u,v,p;
typedef pair<int,int> vec;
vec b;
void foo(){
	int s=*min_element(a,a+n);
	for(int i=0;i!=n;++i)
		a[i]-=s;
	set<int> t;
	for(int i=0,j=0;i!=n;++i){
		while(t.count(a[i])
		||a[i]%d!=a[j]%d)
			t.erase(a[j++]);
		f[i]=j;
		t.insert(a[i]);
	}
	for(int i=0,j=0,k=0;
	k!=n;++k,++z){
		a[u[i+1]=k]/=d;
		while(i&&a[p[i]]>a[k])
			--i;
		p[++i]=v[j+1]=k;
		change(0,-a[k],u[i],k);
		while(j&&a[q[j]]<a[k])
			--j;
		q[++j]=k;
		change(1,a[k],v[j],k);
		int s=query(f[k],k);
		b=max(b,vec(k-s+1,-s));
	}
}
void bar(){
	for(int i=0;i!=n;++i){
		int j=i;
		while(i+1!=n&&a[i]==a[i+1])
			++i;
		b=max(b,vec(i-j+1,-j));
	}
}
int main(){
	scanf("%d%d%d",&n,&z,&d);
	for(int i=0;i!=n;++i)
		scanf("%d",a+i);
	(d?foo:bar)();
	printf("%d %d\n",1-b.second,
	b.first-b.second);
}

  

BZOJ4527: K-D-Sequence 线段树的更多相关文章

  1. 2016暑假多校联合---Rikka with Sequence (线段树)

    2016暑假多校联合---Rikka with Sequence (线段树) Problem Description As we know, Rikka is poor at math. Yuta i ...

  2. Wow! Such Sequence!(线段树4893)

    Wow! Such Sequence! Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others ...

  3. Codeforces Round #250 (Div. 1) D. The Child and Sequence 线段树 区间取摸

    D. The Child and Sequence Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest ...

  4. hdu4893Wow! Such Sequence! (线段树)

    Problem Description Recently, Doge got a funny birthday present from his new friend, Protein Tiger f ...

  5. HDU 6047 Maximum Sequence(线段树)

    题目网址:http://acm.hdu.edu.cn/showproblem.php?pid=6047 题目: Maximum Sequence Time Limit: 4000/2000 MS (J ...

  6. Codeforces 438D The Child and Sequence - 线段树

    At the children's day, the child came to Picks's house, and messed his house up. Picks was angry at ...

  7. hdu 4893 Wow! Such Sequence!(线段树)

    题目链接:hdu 4983 Wow! Such Sequence! 题目大意:就是三种操作 1 k d, 改动k的为值添加d 2 l r, 查询l到r的区间和 3 l r. 间l到r区间上的所以数变成 ...

  8. hdu-5805 NanoApe Loves Sequence(线段树+概率期望)

    题目链接: NanoApe Loves Sequence Time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 262144/131072 ...

  9. Codeforces 486E LIS of Sequence(线段树+LIS)

    题目链接:Codeforces 486E LIS of Sequence 题目大意:给定一个数组.如今要确定每一个位置上的数属于哪一种类型. 解题思路:先求出每一个位置选的情况下的最长LIS,由于開始 ...

  10. Codeforces Round #250 (Div. 1) D. The Child and Sequence 线段树 区间求和+点修改+区间取模

    D. The Child and Sequence   At the children's day, the child came to Picks's house, and messed his h ...

随机推荐

  1. [BZOJ1263][SCOI2006]整数划分(数学+高精度)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1263 分析:数学老师上课讲过啦= =,就是尽可能3越多越好.然后就写个高精度就行了.

  2. JavaScript学习笔记-循环输出菱形,并可菱形自定义大小

    var Cen = 6;//定义菱形中部为第几行(起始值为0) //for循环输出菱形 document.write("<button onclick='xh()'>点我for循 ...

  3. mysql性能优化-慢查询分析、优化索引和配置

    一.优化概述 二.查询与索引优化分析 1性能瓶颈定位 Show命令 慢查询日志 explain分析查询 profiling分析查询 2索引及查询优化 三.配置优化 1)      max_connec ...

  4. Bete冲刺第六阶段

    Bete冲刺第六阶段 github:https://github.com/RadioGroup/JourneyHelper 今日工作: web: 陈灿:新增了用户信息更新接口,优化了部分接口逻辑,更新 ...

  5. PHP自学链接收藏

    PHP之道 laravist Sublime Text 3

  6. 使用iframe标签结合springMvc做文件上传

    1.iframe.jsp <body> <h1>测试iframe文件上传</h1> <!-- 1.要求表单的target属性名称与iframe的name名字一 ...

  7. Android studio配置Git

    Android studio配置Git 1.下载window 版git并安装:下载地址 2.Android Studio设置git插件:File->Setting->Version Con ...

  8. LRU设计

    list是双向链表,map保存key对应到list中的迭代器的位置,list保存<key,value> class LRUCache{ public: LRUCache(int capac ...

  9. flex布局无法自动适应的bug以及实现textarea根据内容自适应

    -webkit-box布局无法自动适应高度的bug css3的新属性display:-webkit-box带来了前端开发自动适应布局的春天 ,但是我发现这个布局有个问题, 而且这个问题我无法解决: 描 ...

  10. java-Date、String、Calendar转化

    1.Calendar 转化 String //获取当前时间的具体情况,如年,月,日,week,date,分,秒等 Calendar calendat = Calendar.getInstance(); ...