思路:

外围一个权值线段树

里面是个区间线段树

搞一个标记永久化

//By SiriusRen
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
#define N 100050
#define int long long
int n,m,op,xx,yy,zz,cnt,root[N*16],lson[N*160],rson[N*160];
int tree[N*160],lazy[N*160];
void insert(int l,int r,int &rt){
if(!rt)rt=++cnt;
if(l>=xx&&r<=yy){tree[rt]+=r-l+1,lazy[rt]++;return;}
int mid=(l+r)>>1;
if(mid<xx)insert(mid+1,r,rson[rt]);
else if(mid>=yy)insert(l,mid,lson[rt]);
else insert(l,mid,lson[rt]),insert(mid+1,r,rson[rt]);
tree[rt]+=(min(yy,r)-max(xx,l)+1);
}
void Insert(int l,int r,int pos){
insert(1,n,root[pos]);
if(l==r)return;
int mid=(l+r)>>1,Lson=pos<<1,Rson=pos<<1|1;
if(mid<zz)Insert(mid+1,r,Rson);
else Insert(l,mid,Lson);
}
int query(int l,int r,int rt){
if(!rt)return 0;
if(l>=xx&&r<=yy)return tree[rt];
int mid=(l+r)>>1,ret=0;
if(mid>=xx)ret+=query(l,mid,lson[rt]);
if(mid<yy)ret+=query(mid+1,r,rson[rt]);
return ret+lazy[rt]*(min(yy,r)-max(xx,l)+1);
}
int Query(int l,int r,int pos){
if(l==r){return l-50001;}
int mid=(l+r)>>1,Lson=pos<<1,Rson=pos<<1|1;
int res=query(1,n,root[Rson]);
if(res>=zz)return Query(mid+1,r,Rson);
else{zz-=res;return Query(l,mid,Lson);}
}
signed main(){
scanf("%lld%lld",&n,&m);
for(int i=1;i<=m;i++){
scanf("%lld%lld%lld%lld",&op,&xx,&yy,&zz);
if(op==1)zz+=50001,Insert(1,N,1);
else printf("%lld\n",Query(1,N,1));
}
}

最新文章

  1. Jquery和Javascript 实际项目中写法基础-ajax和json (3)
  2. 单元测试 &ndash; ASP.NET MVC 4 系列
  3. 使用Git命令上传本地项目
  4. java高薪之路__008_Annotation
  5. Navicat for MySQL数据库管理工具
  6. HDU 4832 Chess(DP+组合数学)(2014年百度之星程序设计大赛 - 初赛(第二轮))
  7. [转]ubuntu(12.04)下, 命令 ,内核 源代码的获取
  8. AIR串口通信
  9. problem 1 -- Two sum
  10. linux 调度器配制参数
  11. C# DBNULL与NULL之间的区别【转】
  12. BootStrap -- Grid System
  13. 《天书夜读:从汇编语言到windows内核编程》八 文件操作与注册表操作
  14. 想了解SAW,BAW,FBAR滤波器的原理?看这篇就够了!
  15. python3 打开页面后多窗口处理三种方法
  16. 第四周读书笔记——读《我是一只IT小小鸟》有感
  17. ubuntu14.04下搜狗输入法不能输入中文问题解决
  18. Sublime Text 3中文乱码问题解决(最新)
  19. VS2012 创建的entityframework 4.1版本
  20. stable

热门文章

  1. Leetcode_num1_Single Number
  2. VS 2013+Qt 5.4.1
  3. TRIZ系列-创新原理-34-抛弃和再生部件原理
  4. 个人andriod实习小作品,个人联网笔记本
  5. BZOJ 3112 [Zjoi2013]防守战线 线性规划
  6. [雅礼NOIP2018集训 day4]
  7. ECharts 在winform中使用(访问JS)
  8. setUserVisibleHint的使用.执行顺序和viewPager.setOffscreenPageLimit(0)不管用还是默认会加载第二个fragment
  9. 编 写高性能的 SQL 语句注意事项
  10. Failed to connect to server