传送门

code:

//By Menteur_Hxy
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<set>
using namespace std; int rd() {
int x=0,fla=1; char c=' ';
while(c>'9'|| c<'0') {if(c=='-') fla=-fla; c=getchar();}
while(c<='9'&&c>='0') x=x*10+c-'0',c=getchar();
return x*fla;
} const int MAX=100005;
const int INF=0x3f3f3f3f;
int n,blo;
int v[MAX],bl[MAX],tag[MAX];
set <int> st[205]; void add(int a,int b,int c) {
for(int i=a;i<=min(bl[a]*blo,b);i++) {
st[bl[a]].erase(v[i]);
v[i]+=c;
st[bl[a]].insert(v[i]);
}
if(bl[a]!=bl[b]) {
for(int i=(bl[b]-1)*blo+1;i<=b;i++) {
st[bl[b]].erase(v[i]);
v[i]+=c;
st[bl[b]].insert(v[i]);
}
}
for(int i=bl[a]+1;i<=bl[b]-1;i++)
tag[i]+=c;
} int query(int a,int b,int c) {
int ans=-1;
for(int i=a;i<=min(bl[a]*blo,b);i++)
if(v[i]+tag[bl[a]]<c) ans=max(ans,v[i]+tag[bl[a]]);
if(bl[a]!=bl[b])
for(int i=(bl[b]-1)*blo+1;i<=b;i++)
if(v[i]+tag[bl[b]]<c) ans=max(ans,v[i]+tag[bl[b]]);
for(int i=bl[a]+1;i<=bl[b]-1;i++) {
int x=c-tag[i];
set<int>::iterator it=st[i].lower_bound(x);
if(it==st[i].begin()) continue;
--it;
ans=max(ans,*it+tag[i]);
}
return ans;
} int main() {
n=rd(); blo=1000;//1000玄学
// cout<<n<<endl;
for(int i=1;i<=n;i++) v[i]=rd();
for(int i=1;i<=n;i++) {
bl[i]=(i-1)/blo+1;
st[bl[i]].insert(v[i]);
}
for(int i=1;i<=n;i++) {
int opt=rd(),l=rd(),r=rd(),c=rd();
if(opt) printf("%d\n",query(l,r,c));
else add(l,r,c);
}
return 0;
}

最新文章

  1. 文件上传命令rz和下载命令sz的安装
  2. c++ operator操作符的两种用法:重载和隐式类型转换,string转其他基本数据类型的简洁实现string_cast
  3. Grunt上手指南&lt;转&gt;
  4. 请问view controller scene,该如何删除
  5. Aisen仿新浪微博客户端项目源码
  6. Webstorm6的汉化以及主题设置
  7. ArduinoYun教程之配置Arduino Yun环境
  8. Fedora Linux 下安装配置C开发环境Code::Blocks
  9. iOS的CocoaPods(activesupport requires Ruby version &gt;= 2.2.2)
  10. js获取css样式封装
  11. Eclipse Golang 开发环境搭建 GoClipse 插件
  12. [01] Collection和Map
  13. Machine.config与web.config
  14. Linux开机自动挂载windows网络共享
  15. redis的键命令
  16. 45.更新一下scrapy爬取工商信息爬虫代码
  17. JPEG/PNG/GIF图片格式简析
  18. [mysql] 随机查询 效率比较
  19. In-app Billing 概述
  20. scrapy 安装技巧

热门文章

  1. [bzoj1316]树上的询问_点分治
  2. P2310 loidc,看看海
  3. iOS UIToolBar的使用
  4. POJ 2068
  5. 创建MFC应用程序的类型:单文档+多文档+基于对话框
  6. (转)Android开发书籍推荐:从入门到精通系列学习路线书籍介绍
  7. 【概率证明】—— sum and product rules of probability
  8. C++字符串与指针 所有的内容也就这么多了。
  9. js设计模式-桥接模式
  10. springboot的推荐模板引擎-Thymeleaf