bzoj3932 任务查询系统
Description
Input
Output
#include<cstdio>
#include<algorithm>
typedef long long lint;
const int N=,mx=;
int m,n;
struct op{
int t,v;
bool s;
op(){}
op(int t_,int v_,bool s_):t(t_),v(v_),s(s_){}
};
bool operator<(op a,op b){
return a.t<b.t;
}
op ops[];
int opp=;
int vs[],vp=;
int lc[N],rc[N],sz[N];
lint sum[N];
int rts[];
int p=;
lint get(int w,int x,int L,int R){
//printf("g[%d,%d] x:%d\n",L,R,x);
int M=L+R>>;
if(sz[w]<=x)return sum[w];
if(L==R)return vs[L-]*1ll*x;
if(sz[lc[w]]>=x)return get(lc[w],x,L,M);
return sum[lc[w]]+get(rc[w],x-sz[lc[w]],M+,R);
}
int add(int w,int v,bool s,int x,int L,int R){
//printf("[%d,%d] v:%d s:%d x:%d\n",L,R,v,(int)s,x);
int u=p++;
if(L==R){
if(s){
sz[u]=sz[w]+;
sum[u]=sum[w]+v;
}else{
sz[u]=sz[w]-;
sum[u]=sum[w]-v;
}
lc[u]=rc[u]=;
}else{
int M=L+R>>;
if(x>M){
rc[u]=add(rc[w],v,s,x,M+,R);
lc[u]=lc[w];
}else{
lc[u]=add(lc[w],v,s,x,L,M);
rc[u]=rc[w];
}
sz[u]=sz[lc[u]]+sz[rc[u]];
sum[u]=sum[lc[u]]+sum[rc[u]];
}
return u;
}
int build(int L,int R){
int w=p++;
int M=L+R>>;
if(L<R){
lc[w]=build(L,M);
rc[w]=build(M+,R);
}
sz[w]=sum[w]=;
return w;
}
int main(){
int a,b,c,x;
lint pre=1ll;
scanf("%d%d",&m,&n);
for(int i=;i<m;i++){
scanf("%d%d%d",&a,&b,&c);
ops[opp++]=op(a,c,);
ops[opp++]=op(b+,c,);
vs[vp++]=c;
}
std::sort(ops,ops+opp);
std::sort(vs,vs+vp);
int vm=vp;vp=;
for(int i=;i<vm;i++)if(vs[i]>vs[i-])vs[vp++]=vs[i];
rts[]=build(,mx);
for(int i=,oi=;i<=n;i++){
rts[i]=rts[i-];
while(oi<opp&&ops[oi].t==i){
rts[i]=add(rts[i],ops[oi].v,ops[oi].s,std::upper_bound(vs,vs+vp,ops[oi].v)-vs,,mx);
oi++;
}
}
for(int i=;i<=n;i++){
scanf("%d%d%d%d",&x,&a,&b,&c);
pre=get(rts[x],(a*pre%c+b)%c+,,mx);
printf("%lld\n",pre);
}
return ;
}
bzoj3932 任务查询系统的更多相关文章
- 【BZOJ3932】[CQOI2015]任务查询系统 主席树
[BZOJ3932][CQOI2015]任务查询系统 Description 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si, ...
- BZOJ3932 CQOI2015 任务查询系统 【主席树】
BZOJ3932 CQOI2015 任务查询系统 Description 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的任务用三元组(Si,Ei, ...
- [bzoj3932][CQOI2015]任务查询系统_主席树
任务查询系统 bzoj-3932 CQOI-2015 题目大意:最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的任务用三元组(Si,Ei,Pi)描述 ...
- 【BZOJ3932】任务查询系统(主席树)
[BZOJ3923]任务查询系统(主席树) 题面 Description 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei ...
- BZOJ3932: [CQOI2015]任务查询系统 主席树
3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 4869 Solved: 1652[Submit][St ...
- bzoj3932 / P3168 [CQOI2015]任务查询系统(主席树+差分)
P3168 [CQOI2015]任务查询系统 看到第k小,就是主席树辣 对于每一段任务(a,b,k),在版本a的主席树+k,版本b+1的主席树-k 同一时间可能有多次修改,所以开个vector存操作, ...
- BZOJ_3932_[CQOI2015]任务查询系统_主席树
BZOJ_3932_[CQOI2015]任务查询系统_主席树 题意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,P ...
- P3168 [CQOI2015]任务查询系统
题目地址:P3168 [CQOI2015]任务查询系统 主席树的模板题 更模板的在这儿:P3834 [模板]可持久化线段树 1(主席树) 形象的说,P3834是"单点修改,区间查询" ...
- 主席树||可持久化线段树||离散化||[CQOI2015]任务查询系统||BZOJ 3932||Luogu P3168
题目: [CQOI2015]任务查询系统 题解: 是一道很经典的题目.大体思路是抓优先级来当下标做主席树,用时刻作为主席树的版本.然而优先级范围到1e7去了,就离散化一遍.然后把每个事件的开始(s). ...
随机推荐
- Oracle11g 查询长时间运行的SQL
一.大量的查询 某些时候,因为SQL的问题,导致数据库的session大量积压,服务器的磁盘读增大,CPU使用率剧增.一般这种SQL,都是一些全表扫描.多表关联.报表或者排序类的SQL.这中情况很有可 ...
- pyqt(二) 创建第一个程序(helloworld)解决object has no attribute 'setCentralWidget'
1.运行Qt Creator QtCreator主界面分为了6个模式:欢迎模式.编辑模式.设计模式.Debug调试模式.项目模式和帮助模式,分别由左侧的6个图标进行切换,对应的快捷键是Ctrl + 数 ...
- ansible with_subelements
with_subelements 循环列表中的子元素 (意想不到的地方会用到) --- - hosts: web tasks: - authorized_key: "user={{ item ...
- <NET CLR via c# 第4版>笔记 第11章 事件
11.1 设计要公开事件的类型 11.1.1 第一步: 定义类型来容纳所有需要发送给事件通知接收者的附加信息 //第一步:定义一个类型来容纳所有应该发送给事件通知接收者的附加信息 internal c ...
- C#中datagridview选中行后textbox显示选中的内容
我想让datagridview中某一行被选中时,textbox中显示选中的值,datagridview的选中模式是整行:this.dataGridView1.SelectionMode = DataG ...
- vue-resource 上传图片
const formData = new FormData()formData.append('file',img,params.name);formData.append('id',params.i ...
- ReactNative——UI1.登录界面样式设置
使用React 基本组件结合flex 属性,实现简单登录布局UI 效果 效果预览:
- STM32 LSM6DSL 陀螺仪数据采集
/************************************************************************************ * STM32 LSM6DS ...
- 20155225 2016-2017-2 《Java程序设计》第五周学习总结
20155225 2006-2007-2 <Java程序设计>第五周学习总结 教材学习内容总结 使用try.catch异常处理,异常处理继承架构等 使用Collection收集对象,了解C ...
- CTF-练习平台-Misc之 Linux基础1
十四.Linux基础1 下载打开文件,解压后发下是一个没有后缀名的文件,添加后缀名为txt,搜索关键词“KEY”,发现flag Linux???不存在的!