题意:n个竹子,有高度,q次询问,询问之间是独立的,每次查询输入l,r,x,y代表砍区间[l,r]]内的竹子砍y次,最后一次要砍成0,每次砍掉的总长度相同,问第x次砍的高度是多少。

既然每次要求砍掉的东西都相同,那么就可以直接算出来砍第x次需要砍掉多少(sumh(l~r)/y*x),然后只需要二分这个高度,在主席树中查找大于等于这个高度的竹子总和减去个数乘以高度即可。

因为主席树的本质是由多颗权值线段树

#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int mod = ;
const int M = + ;
const int N = + ;
ll pre[N];
struct no{
int ls,rs;
ll sum,num;
}tree[N<<];
int rt[N],cnt;
void build(int &now , int l , int r){
now=++cnt;
tree[now].num=tree[now].sum=;
if(l==r) return ;
int mid=(l+r)>>;
build(tree[now].ls,l,mid);
build(tree[now].rs,mid+,r);
}
void update(int &now, int pre, int val, int l, int r){
now=++cnt;
tree[now]=tree[pre];
if(l==r){
tree[now].num++;
tree[now].sum+=val;
return ;
}
int mid=(l+r)>>;
if(val<=mid) update(tree[now].ls,tree[pre].ls,val,l,mid);
else update(tree[now].rs,tree[now].rs,val,mid+,r);
tree[now].num = tree[tree[now].ls].num + tree[tree[now].rs].num;
tree[now].sum = tree[tree[now].ls].sum + tree[tree[now].rs].sum;
}
ll query_num(int p, int q, int L, int R, int l, int r){
if(L <= l && r <= R) return tree[q].num - tree[p].num;
int mid = (l + r) >> ;
ll ans = ;
if(L <= mid) ans += query_num(tree[p].ls, tree[q].ls, L, R, l, mid);
if(mid < R) ans += query_num(tree[p].rs, tree[q].rs, L, R, mid + , r);
return ans;
}
ll query_sum(int p, int q, int L, int R , int l , int r)
{
if(L <= l && r <= R) return tree[q].sum - tree[p].sum;
int mid = (l + r) >> ;
ll ans = ;
if(L <= mid) ans += query_sum(tree[p].ls, tree[q].ls, L, R, l, mid);
if(mid < R) ans += query_sum(tree[p].rs, tree[q].rs, L, R, mid + , r);
return ans;
}
int main(){
int n,q;
scanf("%d%d",&n,&q);
build(rt[],,N);
for(int i= ; i<=n ; i++){
ll h;
scanf("%lld",&h);
pre[i]=pre[i-]+h;
update(rt[i],rt[i-],h,,N);
}
while(q--){
ll l,r,x,y;
scanf("%lld%lld%lld%lld",&l,&r,&x,&y);
double ql=,qr=N;
while(qr-ql>1e-){
double mid=(ql+qr)/;
ll qmid=ceil(mid);
ll qsum=query_sum(rt[l-],rt[r],qmid,N,,N);
ll qnum=query_num(rt[l-],rt[r],qmid,N,,N);
if(qsum-qnum*mid>=1.0*(pre[r]-pre[l-])*x/y) ql=mid;
else qr=mid;
}
printf("%.10lf\n", qr);
}
return ;
}

2019牛客暑期多校训练营(第九场)H Cutting Bamboos(主席树+二分)的更多相关文章

  1. 2019牛客暑期多校训练营(第九场) D Knapsack Cryptosystem

    题目 题意: 给你n(最大36)个数,让你从这n个数里面找出来一些数,使这些数的和等于s(题目输入),用到的数输出1,没有用到的数输出0 例如:3  4 2 3 4 输出:0 0 1 题解: 认真想一 ...

  2. 牛客网多校训练第九场H Cutting Bamboos

    题目链接:https://ac.nowcoder.com/acm/contest/889/H 题意:给出n颗竹子的高度,q次询问,每次询问给出l,r,x,y,每次选取[l,r]中的竹子,砍y次砍掉所有 ...

  3. 2019牛客暑期多校训练营(第二场) H-Second Large Rectangle(单调栈)

    题意:给出由01组成的矩阵,求求全是1的次大子矩阵. 思路: 单调栈 全是1的最大子矩阵的变形,不能直接把所有的面积存起来然后排序取第二大的,因为次大子矩阵可能在最大子矩阵里面,比如: 1 0 0 1 ...

  4. [题解] 2019牛客暑期多校第三场H题 Magic Line

    题目链接:https://ac.nowcoder.com/acm/contest/883/H 题意:二维平面上有n个不同的点,构造一条直线把平面分成两个点数相同的部分. 题解:对这n个点以x为第一关键 ...

  5. 2019牛客多校第⑨场H Cutting Bamboos(主席树+二分)

    原题:https://ac.nowcoder.com/acm/contest/889/H 题意: 给你一些竹子,q个询问,问你从第l到第r个竹子,如果你要用y次砍完它,并且每次砍下来的长度是相同的,问 ...

  6. 2019牛客暑期多校训练营(第五场)G - subsequeue 1 (一题我真的不会的题)

    layout: post title: 2019牛客暑期多校训练营(第五场)G - subsequeue 1 (一题我真的不会的题) author: "luowentaoaa" c ...

  7. 2019牛客暑期多校训练营(第九场)A:Power of Fibonacci(斐波拉契幂次和)

    题意:求Σfi^m%p. zoj上p是1e9+7,牛客是1e9:  对于这两个,分别有不同的做法. 前者利用公式,公式里面有sqrt(5),我们只需要二次剩余求即可.     后者mod=1e9,5才 ...

  8. [状态压缩,折半搜索] 2019牛客暑期多校训练营(第九场)Knapsack Cryptosystem

    链接:https://ac.nowcoder.com/acm/contest/889/D来源:牛客网 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 262144K,其他语言52428 ...

  9. 2019牛客暑期多校训练营(第一场)A题【单调栈】(补题)

    链接:https://ac.nowcoder.com/acm/contest/881/A来源:牛客网 题目描述 Two arrays u and v each with m distinct elem ...

  10. 2019牛客暑期多校训练营(第一场) B Integration (数学)

    链接:https://ac.nowcoder.com/acm/contest/881/B 来源:牛客网 Integration 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 5242 ...

随机推荐

  1. 一些输出、处理细节&注意点

    https://blog.csdn.net/qq_41071646/article/details/79953476 输出百分比的时候,结果需要加上一个EPS(1e-6)四舍五入保证精度. 卡精度—— ...

  2. 5G调研与总结

    5G的重点是: 将极大地超越现有的4G,主要包括速度,时延,带宽,能耗等方面 传输速度的快速提高(相对于4G来说提升了近10倍),在万物物联上的作用会更大 由于传速度快,让各种远程操控成为了可能(AR ...

  3. springboot启动时报错 错误: 找不到或无法加载主类 com.xxx.xxx.Application

    1. Q1 错误: 找不到或无法加载主类 com.xxx.xxx.Application 解决办法:啥也不动,maven clean下,重启 1. Q2 layui控制下拉框高度 解决 .layui- ...

  4. redis两种持久化的方法

    Redis是一种高级key-value数据库.它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富.有字符串,链表,集 合和有序集合.支持在服务器端计算集合的并,交和补集(diff ...

  5. CentOS 添加硬盘创建并挂载分区

    分区工具介绍: fdisk 创建MBR分区:所支持的最大卷:2T,而且对分区有限制:最多4个主分区或3个主分区加一个扩展分区 gdisk 创建GPT分区:突破MBR 4个主分区限制,每个磁盘最多支持1 ...

  6. C++调用C#类库函数

    最近做一个信息化三维仿真项目,基于第三方提供的虚拟引擎通过VC++2008做二次开发,其中涉及到与C#客户端的融合以及数据交互的问题, 主要是VC++需要调用C#客户端提供的类库内的接口获取C#客户端 ...

  7. Java开发第一次面试经验(视频面试)

    坐标:山东潍坊公共实训基地 面试岗位:java开发实习生 我们班级一共6个人一起面试,1对1,其他人坐在旁边倾听,两个大牛,四个酱油,我应该是最黑的酱油啦. 面试问题: 1.请简短的做一下自我介绍: ...

  8. k3 cloud成本调整单

    做了成本调整单中的入库调整单或者出库调整单,进行入库成本核算和出库成本核算,做了入库调整单后在存货收发汇总表(按日期报表)中的收入部分会展示出来: 如果做的是期末余额成本调整,核算时会先删除手工新增的 ...

  9. vue 中使用style(样式)

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. CentOS7安装mysql8.0编译报错集合

    以下都是我安装mysql8.0遇到的一些报错和解决方法 1.does not appear to contain CMakeLists.txt. 原因:mysql下载的源码包不对 解决方法:下载正确的 ...