Codeforces Round #305 (Div. 2) D题 (线段树+RMQ)
1 second
256 megabytes
standard input
standard output
Mike is the president of country What-The-Fatherland. There are n bears living in this country besides Mike. All of them are standing in a line and they are numbered from 1 to n from left to right. i-th bear is exactly ai feet high.

A group of bears is a non-empty contiguous segment of the line. The size of a group is the number of bears in that group. The strengthof a group is the minimum height of the bear in that group.
Mike is a curious to know for each x such that 1 ≤ x ≤ n the maximum strength among all groups of size x.
The first line of input contains integer n (1 ≤ n ≤ 2 × 105), the number of bears.
The second line contains n integers separated by space, a1, a2, ..., an (1 ≤ ai ≤ 109), heights of bears.
Print n integers in one line. For each x from 1 to n, print the maximum strength among all groups of size x.
10
1 2 3 4 5 4 3 2 1 6
6 4 4 3 3 2 2 1 1 1 先用ST算法处理出一段区间内最小值。二分查询出对于第i个数,以它为最小向左或向右可达的最值,得到区间长度为r-l+1。那么,对于group长度为1,2,3,....r-l+1最小值为第i个数的值。则区间更新这些组大小,取最大值。此处可以使用线段树维护。
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cmath>
using namespace std;
const int N=200050;
const int inf=1e9+107; int feet[N];
int st[N][20];
int seg[N<<2];
int ans[N];
void pushdown(int rt){
seg[rt<<1]=max(seg[rt<<1],seg[rt]);
seg[rt<<1|1]=max(seg[rt<<1|1],seg[rt]);
seg[rt]=-1;
} void ST(int num){
for(int i=1;i<=num;i++)
st[i][0]=feet[i];
for(int j=1;j<20;j++)
for(int i=1;i<=num;i++){
if(i+(1<<j)-1 <= num){
st[i][j]=min(st[i][j-1],st[i+(1<<(j-1))][j-1]);
}
}
} void update(int rt,int l,int r,int L,int R,int val){
if(l<=L&&R<=r){
if(val>seg[rt]) seg[rt]=val; return;
}
int m=(L+R)>>1;
pushdown(rt);
if(r<=m){
update(rt<<1,l,r,L,m,val);
}
else if(l>=m+1){
update(rt<<1|1,l,r,m+1,R,val);
}
else{
update(rt<<1,l,r,L,m,val);
update(rt<<1|1,l,r,m+1,R,val);
}
} void dfs(int rt,int L,int R){
if(L==R){
ans[L]=seg[rt];
return ;
}
pushdown(rt);
int m=(L+R)>>1;
dfs(rt<<1,L,m);
dfs(rt<<1|1,m+1,R);
} int query(int l,int r){
int k=(int)((log(r-l+1))/log(2.0));
int maxl=min(st[l][k],st[r-(1<<k)+1][k]);
return maxl;
} int main(){
int n;
while(scanf("%d",&n)!=EOF){
for(int i=1;i<=(n<<2)+10;i++){
seg[i]=-1;
}
for(int i=1;i<=n;i++){
scanf("%d",&feet[i]);
}
ST(n);
for(int i=1;i<=n;i++){
//left
int l=1,r=i;
int L=i,R=i;
while(l<=r){
int m=(l+r)>>1;
int index=query(m,i);
if(index>=feet[i]){
r=m-1;
L=m;
}
else {
l=m+1;
}
}
//right
l=i,r=n;
while(l<=r){
int m=(l+r)>>1;
int index=query(i,m);
if(index>=feet[i]){
l=m+1;
R=m;
}
else {
r=m-1;
}
}
update(1,1,R-L+1,1,n,feet[i]);
}
dfs(1,1,n);
printf("%d",ans[1]);
for(int i=2;i<=n;i++)
printf(" %d",ans[i]);
printf("\n");
}
return 0;
}
Codeforces Round #305 (Div. 2) D题 (线段树+RMQ)的更多相关文章
- Codeforces Round #603 (Div. 2) E. Editor 线段树
E. Editor The development of a text editor is a hard problem. You need to implement an extra module ...
- Codeforces Round #765 Div.1 F. Souvenirs 线段树
题目链接:http://codeforces.com/contest/765/problem/F 题意概述: 给出一个序列,若干组询问,问给出下标区间中两数作差的最小绝对值. 分析: 这个题揭示着数据 ...
- Codeforces Codeforces Round #316 (Div. 2) C. Replacement 线段树
C. ReplacementTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/570/problem ...
- Codeforces Round #406 (Div. 1) B. Legacy 线段树建图跑最短路
B. Legacy 题目连接: http://codeforces.com/contest/786/problem/B Description Rick and his co-workers have ...
- 【转】Codeforces Round #406 (Div. 1) B. Legacy 线段树建图&&最短路
B. Legacy 题目连接: http://codeforces.com/contest/786/problem/B Description Rick and his co-workers have ...
- Codeforces Round #406 (Div. 2) D. Legacy 线段树建模+最短路
D. Legacy time limit per test 2 seconds memory limit per test 256 megabytes input standard input out ...
- Codeforces Round #278 (Div. 1) Strip (线段树 二分 RMQ DP)
Strip time limit per test 1 second memory limit per test 256 megabytes input standard input output s ...
- Codeforces Round #305 (Div. 2) E题(数论+容斥原理)
E. Mike and Foam time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...
- Codeforces Round #305 (Div. 2) C题 (数论)
C. Mike and Frog time limit per test 1 second memory limit per test 256 megabytes input standard inp ...
随机推荐
- Springboot2.0部署阿里云服务器(nginx+域名+SSL)供Http和Https访问
总算是弄出来了,先写下来供自己以后查阅. 1)首先你要有一个阿里云服务器,我用的是Centos7学生认证,10元/月,很便宜也很好用. 2)购买了域名,首年9元,很划算.域名买来之后经历了拍照备案,前 ...
- ZOJ3714JavaBeans
#!/usr/bin/env python # encoding: utf-8 t = int(raw_input()) for i in range(t): n,k = [int(x) for x ...
- HTML--使用mailto在网页中链接Email地址
<a>标签还有一个作用是可以链接Email地址,使用mailto能让访问者便捷向网站管理者发送电子邮件.我们还可以利用mailto做许多其它事情.下面一一进行讲解,请看详细图示: 注意:如 ...
- ACM_求交集
求交集 Time Limit: 2000/1000ms (Java/Others) Problem Description: 输入集合A和B,按大小顺序输出A和B的交集. Input: 输入包含多组测 ...
- MVC系列学习(十三)-合并JS和CSS
1.先来看看,不用合并js的情况,传输量大 1.1新建一个 [基本]的mvc项目 然后新建一个控制器HomeController,因为js会在很多视图中用到,所以此时我们添加一个视图带布局页Index ...
- C#学习-执行存储过程
使用存储的优点 1.执行更快.直接写sql脚本会有个解析编译的过程. 2.修改方便.当业务改变时,只需要改存储过程,不需要修改C#代码 3.传递Sql脚本数据相对更小 缺点: 1.使用存储过程,数据库 ...
- fcc 响应式框架Bootstrap 练习2
text-primary 属性值使标题直接变成了红色,text-center使标题直接居中 <h2 class="text-primary text-center"> ...
- android黑科技系列——获取加固后应用App的所有方法信息
一.前言 在逆向应用的时候,我们有时候希望能够快速定位到应用的关键方法,在之前我已经详细介绍了一个自己研发的代码动态注入工具icodetools,来进行动态注入日志信息到应用中,不了解的同学可以查看这 ...
- html5——背景
背景大小 background-size: % %;//宽 高 background-size: 100px 100px;//宽 高 background-size: cover;//覆盖,图片会完全 ...
- CSS3 background-origin 属性
CSS3 background-origin 属性 padding-box 背景图像相对于内边距框来定位. border-box 背景图像相对于边框盒来定位. content-box 背景图像相对于内 ...