题目链接:https://loj.ac/problem/6279

题目大意:中文题目

具体思路:按照上一个题的模板改就行了,但是注意在整块查找的时候的下标问题。

AC代码:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. # define ll long long
  4. const int maxn = 2e5+;
  5. const int mod = 1e8+;
  6. const int inf = 0x3f3f3f3f;
  7. ll l[maxn],r[maxn],belong[maxn];
  8. ll add[maxn],a[maxn],b[maxn];
  9. int n;
  10. void buildblock()
  11. {
  12. ll tmp=(ll)sqrt(n);
  13. ll tot=n/tmp;
  14. if(n%tmp)
  15. tot++;
  16. for(ll i=; i<=n; i++)
  17. {
  18. belong[i]=(i-)/tmp+1ll;
  19. }
  20. for(ll i=; i<=tot; i++)
  21. {
  22. l[i]=(i-)*tmp+1ll;
  23. r[i]=i*tmp;
  24. }
  25. r[tot]=n;
  26. for(ll i=; i<=tot; i++)
  27. {
  28. sort(b+l[i],b+r[i]+);
  29. }
  30. }
  31. void init(int tmp){
  32. for(int i=l[tmp];i<=r[tmp];i++)b[i]=a[i];
  33. sort(b+l[tmp],b+r[tmp]+);
  34. }
  35. void update(ll st,ll ed,ll val)
  36. {
  37. if(belong[st]==belong[ed])
  38. {
  39. for(ll i=st; i<=ed; i++)a[i]+=val;
  40. init(belong[st]);
  41. return ;
  42. }
  43. for(ll i=st; i<=r[belong[st]]; i++)a[i]+=val;
  44. init(belong[st]);
  45. for(ll i=l[belong[ed]]; i<=ed; i++)a[i]+=val;
  46. init(belong[ed]);
  47. for(ll i=belong[st]+; i<belong[ed]; i++)
  48. add[i]+=val;
  49. }
  50. ll ask(ll st,ll ed,ll val)
  51. {
  52. ll ans=-inf;
  53. if(belong[st]==belong[ed])
  54. {
  55. for(ll i=st; i<=ed; i++)
  56. {
  57. if(a[i]+add[belong[st]]>=val)continue;
  58. ans=max(ans,a[i]+add[belong[st]]);
  59. }
  60. return ans;
  61. }
  62. for(ll i=st; i<=r[belong[st]]; i++)
  63. {
  64. if(a[i]+add[belong[st]]>=val)continue;
  65. ans=max(ans,a[i]+add[belong[st]]);
  66. }
  67. for(ll i=l[belong[ed]]; i<=ed; i++)
  68. {
  69. if(a[i]+add[belong[ed]]>=val)continue;
  70. ans=max(ans,a[i]+add[belong[ed]]);
  71. }
  72. for(ll i=belong[st]+; i<belong[ed]; i++)
  73. {
  74. ll tmp=val-add[i];
  75. ll id=lower_bound(b+l[i],b+r[i]+,tmp)-(b+l[i]);
  76. if(id==)continue;
  77. ans=max(ans,b[l[i]+id-]+add[i]);
  78. }
  79. return ans;
  80. }
  81. int main()
  82. {
  83. // freopen("hqx.in","r",stdin);
  84. // cout<<lower_bound(a,a+5,2)-a<<endl;
  85. scanf("%d",&n);
  86. for(int i=; i<=n; i++)
  87. {
  88. scanf("%lld",&a[i]);
  89. b[i]=a[i];
  90. }
  91. buildblock();
  92. ll op,st,ed;
  93. ll val;
  94. while(n--)
  95. {
  96. scanf("%lld %lld %lld %lld",&op,&st,&ed,&val);
  97. if(op==)
  98. {
  99. update(st,ed,val);
  100. }
  101. else if(op==)
  102. {
  103. ll tmp=ask(st,ed,val);
  104. printf("%lld\n",tmp==-inf?-:tmp);
  105. }
  106. }
  107. return ;
  108. }

#6279. 数列分块入门 3(询问区间内小于某个值 xx 的前驱(比其小的最大元素))的更多相关文章

  1. #6278. 数列分块入门 2(询问区间内小于某个值 xx 的元素个数)

    题目链接:https://loj.ac/problem/6278 题目大意:中文题目 具体思路:数列分块模板题,对于更新的时候,我们通过一个辅助数组来进行,对于原始的数组,我们只是用来加减,然后这个辅 ...

  2. LOJ #6279. 数列分块入门 3-分块(区间加法、查询区间内小于某个值x的前驱(比其小的最大元素))

    #6279. 数列分块入门 3 内存限制:256 MiB时间限制:1500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 3   题目描述 给 ...

  3. LOJ #6278. 数列分块入门 2-分块(区间加法、查询区间内小于某个值x的元素个数)

    #6278. 数列分块入门 2 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 6   题目描述 给出 ...

  4. loj 6278 6279 数列分块入门 2 3

    参考:「分块」数列分块入门1 – 9 by hzwer 2 Description 给出一个长为\(n\)的数列,以及\(n\)个操作,操作涉及区间加法,询问区间内小于某个值\(x\)的元素个数. 思 ...

  5. LOJ #6277. 数列分块入门 1-分块(区间加法、单点查询)

    #6277. 数列分块入门 1 内存限制:256 MiB时间限制:100 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2   题目描述 给出 ...

  6. LOJ #6283. 数列分块入门 7-分块(区间乘法、区间加法、单点查询)

    #6283. 数列分块入门 7 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2   题目描述 给出 ...

  7. LOJ #6281. 数列分块入门 5-分块(区间开方、区间求和)

    #6281. 数列分块入门 5 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 5   题目描述 给出 ...

  8. LOJ #6280. 数列分块入门 4-分块(区间加法、区间求和)

    #6280. 数列分块入门 4 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论   题目描述 给出一个 ...

  9. loj 数列分块入门 6 9(区间众数)

    6 题意 给出一个长为\(n\)的数列,以及\(n\)个操作,操作涉及单点插入,单点询问,数据随机生成. 题解 参考:http://hzwer.com/8053.html 每个块内用一个\(vecto ...

随机推荐

  1. java键盘中输入q退出

    用 java.util.Scanner 如下 public static void main(String[] args) { while(true){ Scanner scan = new Scan ...

  2. 使用perconna xtrabackup备份脚本

    使用percona xtrabackup对两个数据库实例进行备份,备份的脚本如下所示: #!/bin/bash BASEDIR="/usr/local/mysql" BIN=&qu ...

  3. java中异常的面试

    https://blog.csdn.net/qq_36523638/article/details/79363652 1) Java中的检查型异常和非检查型异常有什么区别? 这又是一个非常流行的Jav ...

  4. Explicit Constructors(显式构造函数)

    按照默认规定,只有一个参数的构造函数也定义了一个隐式转换,将该构造函数对应数据类型的数据转换为该类对象,如下面所示:class String {String ( const char* p ); // ...

  5. nginx最简安装

    在 CentOS 6.2  下安装nginx 一:nginx所需依赖的安装 用yum安装依赖: yum -y install zlib zlib-devel openssl openssl-devel ...

  6. bzoj3991 LCA + set

    https://www.lydsy.com/JudgeOnline/problem.php?id=3991 小B最近正在玩一个寻宝游戏,这个游戏的地图中有N个村庄和N-1条道路,并且任何两个村庄之间有 ...

  7. jmeter counter函数问题

    ${__counter(FALSE,)}此函数比较奇怪,放在jsr223前置处理器中引用时不知道为啥,第一个值是2.但是放在其他位置时第一个值是1 真是诡异啊!不知道是不是bug呢 放在标题里引用,t ...

  8. Redash 安装部署

    介绍 是一款开源的BI工具,提供了基于web的数据库查询和数据可视化功能. 官网:https://redash.io/ GitHub:https://github.com/getredash/reda ...

  9. OS + RedHat 6.3 x64 NFS / mount.nfs: access denied by server while mounting

    s Linux mount/unmount命令(转) https://www.cnblogs.com/xd502djj/p/3809375.html 问题2:NFS配置项no_root_squash和 ...

  10. 检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046} 的组件时失 败,原因是出现以下错误: 80080005

    .Net MVC项目,在下载一个Excel的时候总是报错. 解决办法: 在服务器中,运行dcomcnfg打开组件服务, 依次展开"组件服务"->"计算机" ...