BZOJ3932: [CQOI2015]任务查询系统 主席树
3932: [CQOI2015]任务查询系统
Time Limit: 20 Sec Memory Limit: 512 MB
Submit: 4869 Solved: 1652
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1 2 6
2 3 3
1 3 2
3 3 4
3 1 3 2
1 1 3 4
2 2 4 3
Sample Output
8
11
HINT
Source
#include<bits/stdc++.h>
#define ll long long
#define pb push_back
#define _mp make_pair
#define ldb long double
using namespace std;
const int maxn=2e5+100;
inline ll read()
{
ll x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
struct node
{
ll l,r;
ll sum,v;
}no[maxn*40];
struct sr
{
int x,num,tp,val;
}sf[maxn*2];
int id[maxn],nid[maxn],pri[maxn];
ll root[maxn<<1];
int cnt=0,tot=0,n,m;
bool cmp1( int a, int b){
return pri[a]<pri[b];
}
bool cmp2(const sr& a,const sr& b)
{
return a.x<b.x;
}
void insert(ll& now,int l,int r,int pl,int val,int type)
{
no[++cnt]=no[now];
now=cnt;
no[now].v+=type;
no[now].sum+= val;
if(l==r)return;
int mid=(l+r)>>1;
if(pl<=mid)insert(no[now].l,l,mid,pl,val,type);
else if(pl>mid)insert(no[now].r,mid+1,r,pl,val,type);
}
ll query(ll x,int l,int r,ll k)
{
if(l==r)
{
return no[x].sum;
}
int mid=(l+r)>>1;
ll tmp=0;
ll ss=no[no[x].l].v;
if(ss>=k)
{
tmp+=query(no[x].l,l,mid,k);
}
else
{
tmp+=no[no[x].l].sum;
tmp+=query(no[x].r,mid+1,r,k-ss);
}
return tmp;
}
int pp,qq,rr,ss;
int main()
{
n=read();m=read();
for(int i=1;i<=n;i++)
{
pp=read();qq=read();rr=read();
pri[i]=rr;id[i]=i;
sf[++tot].x=pp;sf[tot].val=rr;sf[tot].tp=1;
sf[++tot].x=qq+1;sf[tot].val=-rr;sf[tot].tp=-1;
}
sort(id+1,id+1+n,cmp1);
for(int i=1;i<=n;i++)nid[id[i]] =i;
// for(int i=1;i<=n;i++)cout<<nid[i]<<endl;
for(int i=1;i<=tot;i+=2)
{
sf[i].num=sf[i+1].num=nid[(i+1)/2];
}
sort(sf+1,sf+1+tot,cmp2);
int j=1;
for(int i=1;i<=m;i++)
{
root[i]=root[i-1];
while(sf[j].x==i)
{
insert(root[i],1,n,sf[j].num,sf[j].val,sf[j].tp);
j++;
}
}
//cout<<cnt<<endl;
ll pre=1;
for(int i=1;i<=m;i++)
{
ss=read();pp=read();qq=read();rr=read();
ll tmp=1+(pp*pre+qq)%rr;
//cout<<tmp<<endl;
pre=query(root[ss],1,n,tmp);
printf("%lld\n",pre);
}
}
BZOJ3932: [CQOI2015]任务查询系统 主席树的更多相关文章
- BZOJ3932[CQOI2015]任务查询系统——主席树
题目描述 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第E ...
- BZOJ3932 CQOI2015 任务查询系统 - 主席树,离散化
记录下自己写错的地方吧 1. 区间可能有重复 2. 没有出现的坐标也要计入version (因为询问里可能会有) #include <bits/stdc++.h> using namesp ...
- 【BZOJ3932】[CQOI2015]任务查询系统 主席树
[BZOJ3932][CQOI2015]任务查询系统 Description 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si, ...
- [CQOI2015]任务查询系统 主席树
[CQOI2015]任务查询系统 LG传送门 以前还没见过主席树的这种写法. 考虑使用差分的思想处理每一个任务,然后所有的东西就都能顺理成章地用主席树维护了,查询的时候和平时的主席树有一点不同,详见代 ...
- bzoj 3932: [CQOI2015]任务查询系统 -- 主席树 / 暴力
3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec Memory Limit: 512 MB Description 最近实验室正在为其管理的超级计算机编制一套任务管 ...
- 洛谷P3168 [CQOI2015]任务查询系统 [主席树,差分]
题目传送门 任务查询系统 题目描述 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任 ...
- BZOJ 3932: [CQOI2015]任务查询系统 [主席树]
传送门 题意: 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第Ei秒后结束(第Si秒和Ei秒任务也在运行),其优先级为Pi 调度系统会经常向查询系统询问,第Xi ...
- BZOJ.3932.[CQOI2015]任务查询系统(主席树 差分)
题目链接 对于这一区间的操作,我们可以想到差分+前缀和(感觉也没什么别的了..). 同时对于本题我们能想到主席树,而主席树正是利用前一个节点建树的. 所以离散化.按时间排序,把操作拆成单点加和减即可. ...
- BZOJ 3932: [CQOI2015]任务查询系统 | 主席树练习题
题目: 洛谷也能评测 题解: De了好长时间BUG发现是自己sort前面有一行for没删,气死. 题目询问第x秒时候前k小的P值之和. 朴素想法: 我们可以把P值离散化,然后对于每个时刻建一棵定义域是 ...
随机推荐
- winform使用相关
1.回车键触发按钮点击事件——回车登录 设置窗体的AccessButton属性 2.密码框样式设置 设置PasswordChar为想要的密码显示的样式,如* 3.设置窗口居中 设置StartPosi ...
- 用Python删除本地目录下某一时间点之前创建的文件
参考http://www.cnblogs.com/iderek/p/8035757.html os.listdir(dirname):列出dirname下的目录和文件 os.getcwd():获得当前 ...
- JS—ajax及async和defer的区别
###1.ajax “Asynchronous Javascript And XML”(异步 JavaScript 和 XML) 使用: 如不考虑旧版本浏览器兼容性, // 第一步创建xhr对象 v ...
- C#设计模式之6:抽象工厂模式
前面分析了简单工厂模式和工厂方法模式,接着来看一下抽象工厂模式,他与工厂方法模式有一些相似的地方,也有不同的地方. 先来看一个不用工厂方法模式实现的订购披萨的代码: 对象依赖的问题:当你直接实例化一个 ...
- HDU 3900 Unblock Me
题目:Unblock Me 链接:Here 题意:一个游戏,看图就基本知道题意了,特殊的是:1. 方块长度为3或2,宽度固定是1.2. 地图大小固定是6*6,从0开始. 3. 出口固定在(6,2).4 ...
- Java 线程的创建和启动
Java 使用 Thread 类代表线程,所有的线程对象都必须是 Thread 类或其子类的实例.每个线程的作用是完成一定的任务,实际上就是执行一段程序流(一段顺序执行的代码). Java 使用线程执 ...
- 建议1---理解Pythonic的概念
对于Pythonic的概念,众人都有自己的看法,但大家心中都认同一个更具体的指南,即Tim Peters的<The Zen of Python>.在这一篇充满禅意的诗篇中,有几点非常深入人 ...
- Spark 数据倾斜
Spark 数据倾斜解决方案 2017年03月29日 17:09:58 阅读数:382 现象 当你的应用程序发生以下情况时你该考虑下数据倾斜的问题了: 绝大多数task都可以愉快的执行,总 ...
- 莫烦theano学习自修第八天【分类问题】
1. 代码实现 from __future__ import print_function import numpy as np import theano import theano.tensor ...
- array_merge
1.array_merge 中有两个参数:将两个关联数组合并为一个数组 <?php $a1=array("a"=>"red","b&quo ...