题目传送门//res tp hdu

目的

对长度为n的区间,给定q个子区间,求其元素能构成三角形的最大周长。有多组测试。

n 1e5

q 1e5

ai [1,1e9] (i∈[1,n]);

数据结构

划分树

分析

需在不超过O(logn)的时间内完成一次查询

若一个数列不能构成三角形,则其为斐波那契数列。斐列不超过50项即可达到1e9,故每次只需查询区间的前k大即可,不超过50次询问,即可得到该数列是否能构成三角形

划分树的单次询问第k小/大为logn

#include<iostream>
#include<algorithm>
#include<cmath>
typedef long long ll;
using namespace std;
const int MAXN = 100000+50;
const int DEEP = 20;
ll tree[DEEP][MAXN];
int cnt[DEEP][MAXN];
ll sorted[MAXN];
void build(int deep,int lft,int rht)
{
if(lft == rht) return;
int mid = (lft + rht)>>1;
int scnt = mid - lft + 1;
ll M = sorted[mid];
for(int i = lft;i<=rht;++i){
if(tree[deep][i] < M) scnt--;
}
int p = lft, r = mid + 1;
for(int i = lft,cnt_in_left = 0;i<=rht;++i){
ll num = tree[deep][i];
if(num < M || (num == M && scnt)){
if(num == M) scnt--;
cnt_in_left++;
tree[deep + 1][p++] = num;
}
else tree[deep + 1][r++] = num;
cnt[deep][i] = cnt_in_left;
}
build(deep + 1,lft,mid);
build(deep + 1,mid + 1,rht);
}
ll query(int deep, int lft, int rht, int qlft, int qrht, int k){
if(lft == rht) return tree[deep][lft];
int mid = (lft + rht)>>1;
int left = 0,sum_in_left = cnt[deep][qrht];
if(qlft != lft){
left = cnt[deep][qlft-1];
sum_in_left-=left;
}
if(sum_in_left >= k){
int new_qlft = lft + left;
int new_qrht = new_qlft + sum_in_left - 1;
return query(deep + 1,lft,mid,new_qlft,new_qrht,k);
}
else{
int a = qlft - lft - left;
int b = qrht - qlft - sum_in_left;
int new_qlft = (mid + 1) + a;
int new_qrht = new_qlft + b;
return query(deep+1,mid+1,rht,new_qlft,new_qrht,k - sum_in_left);
}
}
int main()
{
int n,q,l,r;
while(scanf(" %d %d",&n,&q)!=EOF){
for(int i = 1;i<=n;++i) {
scanf(" %lld",&sorted[i]);
tree[0][i] = sorted[i];
}
sort(sorted+1,sorted+1+n);
build(0,1,n);
while(q--){
scanf(" %d %d",&l,&r);
if(r - l + 1 < 3) printf("-1\n");
else{
int len = r - l + 1;
long long a,b,c,ans = -1;
a = query(0,1,n,l,r,len);
b = query(0,1,n,l,r,len-1);
for(int i = len-2;i>=1;--i){
c = query(0,1,n,l,r,i);
if(b + c > a){
ans = a + b + c;break;
}
a= b;b = c;
}
printf("%lld\n",ans);
}
}
}
}

hdu 6601 区间条件极值 - 区间 最大 三角形周长的更多相关文章

  1. hdu 3473 区间条件极值 - 区间 差的绝对值 之和的最小

    题目传送门//res tp hdu 目的 对长度为n的区间,给定q个子区间,求一x,使得区间内所有元素与x的差的绝对值之和最小. 多测. n 1e5 q 1e5 ai [1,1e9] (i∈[1,n] ...

  2. hdu 5919 主席树(区间不同数的个数 + 区间第k大)

    Sequence II Time Limit: 9000/4500 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Tot ...

  3. HDU.1689 Just a Hook (线段树 区间替换 区间总和)

    HDU.1689 Just a Hook (线段树 区间替换 区间总和) 题意分析 一开始叶子节点均为1,操作为将[L,R]区间全部替换成C,求总区间[1,N]和 线段树维护区间和 . 建树的时候初始 ...

  4. HDU 3397 Sequence operation(区间合并 + 区间更新)

    题目链接:pid=3397">http://acm.hdu.edu.cn/showproblem.php?pid=3397 题意:给定n个数,由0,1构成.共同拥有5种操作. 每一个操 ...

  5. hdu 1698 线段树 区间更新 区间求和

    Just a Hook Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  6. hdu6070(分数规划/二分+线段树区间更新,区间最值)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=6070 题意: 给出一个题目提交序列, 从中选出一个正确率最小的子串. 选中的子串中每个题目当且仅当最 ...

  7. 整数区间及区间集合(C#实现)

    /// <summary> /// 整数区间类 /// </summary> private class Interval { , _end = ; public int St ...

  8. HDU 5224 Tom and paper(最小周长)

    HDU 5224 Tom and paper(最小周长) Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d &a ...

  9. [用CDQ分治解决区间加&区间求和]【习作】

    [前言] 作为一个什么数据结构都不会只会CDQ分治和分块的蒟蒻,面对区间加&区间求和这么难的问题,怎么可能会写线段树呢 于是,用CDQ分治解决区间加&区间求和这篇习作应运而生 [Par ...

随机推荐

  1. python 二维数组 转 矩阵

    x = numpy.array([[,,],[,,],[,,]]) print x print x.shape 输出 [[ ] [ ] [ ]] (3L, 3L) [Finished .2s]

  2. springboot(七).springboot整合jedis实现redis缓存

    我们在使用springboot搭建微服务的时候,在很多时候还是需要redis的高速缓存来缓存一些数据,存储一些高频率访问的数据,如果直接使用redis的话又比较麻烦,在这里,我们使用jedis来实现r ...

  3. Ubuntu 16.04 一键安装P4开发环境记录

    写在最前 P4开发环境安装可采用陈翔同学的一键安装脚本:p4Installer p4c-bm是P4-14的编译器,p4c是现在主流P4-16的编译器,bmv2是支持P4运行的软件交换机 系统环境 在安 ...

  4. 【软件工程】Beta冲刺(1/5)

    链接部分 队名:女生都队 组长博客: 博客链接 作业博客:博客链接 小组内容 恩泽(组长) 过去两天完成了哪些任务 描述 tomcat的学习与实现 服务器后端部署,API接口的beta版实现 后端代码 ...

  5. SilverFish

    noHero123/silverfish https://github.com/noHero123/silverfish/blob/master/HrtBddy/instructions.txt Ho ...

  6. python之crawlspider初探

    注意点: """ 1.用命令创建一个crawlspider的模板:scrapy genspider -t crawl <爬虫名> <all_domain ...

  7. mysql数据库指定ip远程访问

    1.登录 mysql -u root -p 之后输入密码进行登陆 2.权限设置及说明 2.1添加远程ip访问权限 GRANT ALL PRIVILEGES ON *.* TO 'root'@'192. ...

  8. iOS tableHeaderView有默认高度?

    在给tableView设置tableHeaderView的时候发现,如果设置tableView.tableHeaderView = [UIView new] , 这里未设置tableView的高度,但 ...

  9. 配置了configuration.xml之后提示找不到映射关系

    在启动类里面单独增加一个Bean即可解决 @Bean public DatabaseIdProvider getDatabaseIdProvider(){ DatabaseIdProvider dat ...

  10. [PySpark] Spark SQL on a large file

    基础篇:[Spark] 03 - Spark SQL /* implement */