hdu 6601 区间条件极值 - 区间 最大 三角形周长
题目传送门//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 区间条件极值 - 区间 最大 三角形周长的更多相关文章
- hdu 3473 区间条件极值 - 区间 差的绝对值 之和的最小
题目传送门//res tp hdu 目的 对长度为n的区间,给定q个子区间,求一x,使得区间内所有元素与x的差的绝对值之和最小. 多测. n 1e5 q 1e5 ai [1,1e9] (i∈[1,n] ...
- hdu 5919 主席树(区间不同数的个数 + 区间第k大)
Sequence II Time Limit: 9000/4500 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Tot ...
- HDU.1689 Just a Hook (线段树 区间替换 区间总和)
HDU.1689 Just a Hook (线段树 区间替换 区间总和) 题意分析 一开始叶子节点均为1,操作为将[L,R]区间全部替换成C,求总区间[1,N]和 线段树维护区间和 . 建树的时候初始 ...
- HDU 3397 Sequence operation(区间合并 + 区间更新)
题目链接:pid=3397">http://acm.hdu.edu.cn/showproblem.php?pid=3397 题意:给定n个数,由0,1构成.共同拥有5种操作. 每一个操 ...
- hdu 1698 线段树 区间更新 区间求和
Just a Hook Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- hdu6070(分数规划/二分+线段树区间更新,区间最值)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=6070 题意: 给出一个题目提交序列, 从中选出一个正确率最小的子串. 选中的子串中每个题目当且仅当最 ...
- 整数区间及区间集合(C#实现)
/// <summary> /// 整数区间类 /// </summary> private class Interval { , _end = ; public int St ...
- HDU 5224 Tom and paper(最小周长)
HDU 5224 Tom and paper(最小周长) Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%I64d &a ...
- [用CDQ分治解决区间加&区间求和]【习作】
[前言] 作为一个什么数据结构都不会只会CDQ分治和分块的蒟蒻,面对区间加&区间求和这么难的问题,怎么可能会写线段树呢 于是,用CDQ分治解决区间加&区间求和这篇习作应运而生 [Par ...
随机推荐
- python 二维数组 转 矩阵
x = numpy.array([[,,],[,,],[,,]]) print x print x.shape 输出 [[ ] [ ] [ ]] (3L, 3L) [Finished .2s]
- springboot(七).springboot整合jedis实现redis缓存
我们在使用springboot搭建微服务的时候,在很多时候还是需要redis的高速缓存来缓存一些数据,存储一些高频率访问的数据,如果直接使用redis的话又比较麻烦,在这里,我们使用jedis来实现r ...
- Ubuntu 16.04 一键安装P4开发环境记录
写在最前 P4开发环境安装可采用陈翔同学的一键安装脚本:p4Installer p4c-bm是P4-14的编译器,p4c是现在主流P4-16的编译器,bmv2是支持P4运行的软件交换机 系统环境 在安 ...
- 【软件工程】Beta冲刺(1/5)
链接部分 队名:女生都队 组长博客: 博客链接 作业博客:博客链接 小组内容 恩泽(组长) 过去两天完成了哪些任务 描述 tomcat的学习与实现 服务器后端部署,API接口的beta版实现 后端代码 ...
- SilverFish
noHero123/silverfish https://github.com/noHero123/silverfish/blob/master/HrtBddy/instructions.txt Ho ...
- python之crawlspider初探
注意点: """ 1.用命令创建一个crawlspider的模板:scrapy genspider -t crawl <爬虫名> <all_domain ...
- mysql数据库指定ip远程访问
1.登录 mysql -u root -p 之后输入密码进行登陆 2.权限设置及说明 2.1添加远程ip访问权限 GRANT ALL PRIVILEGES ON *.* TO 'root'@'192. ...
- iOS tableHeaderView有默认高度?
在给tableView设置tableHeaderView的时候发现,如果设置tableView.tableHeaderView = [UIView new] , 这里未设置tableView的高度,但 ...
- 配置了configuration.xml之后提示找不到映射关系
在启动类里面单独增加一个Bean即可解决 @Bean public DatabaseIdProvider getDatabaseIdProvider(){ DatabaseIdProvider dat ...
- [PySpark] Spark SQL on a large file
基础篇:[Spark] 03 - Spark SQL /* implement */