BZOJ3932 CQOI2015 任务查询系统


Description

最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分。超级计算机中的任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第Ei秒后结束(第Si秒和Ei秒任务也在运行),其优先级为Pi。同一时间可能有多个任务同时执行,它们的优先级可能相同,也可能不同。调度系统会经常向查询系统询问,第Xi秒正在运行的任务中,优先级最小的Ki个任务(即将任务按照优先级从小到大排序后取前Ki个)的优先级之和是多少。特别的,如果Ki大于第Xi秒正在运行的任务总数,则直接回答第Xi秒正在运行的任务优先级之和。上述所有参数均为整数,时间的范围在1到n之间(包含1和n)。

Input

输入文件第一行包含两个空格分开的正整数m和n,分别表示任务总数和时间范围。接下来m行,每行包含三个空格分开的正整数Si、Ei和Pi(Si≤Ei),描述一个任务。接下来n行,每行包含四个空格分开的整数Xi、Ai、Bi和Ci,描述一次查询。查询的参数Ki需要由公式 Ki=1+(Ai*Pre+Bi) mod Ci计算得到。其中Pre表示上一次查询的结果,

对于第一次查询,Pre=1。

Output

输出共n行,每行一个整数,表示查询结果。

Sample Input

4 3

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

2

8

11

HINT

样例解释

K1 = (1*1+3)%2+1 = 1

K2 = (1*2+3)%4+1 = 2

K3 = (2*8+4)%3+1 = 3

对于100%的数据,1≤m,n,Si,Ei,Ci≤100000,0≤Ai,Bi≤100000,1≤Pi≤10000000,Xi为1到n的一个排列


主席树板子题,我们把一个时间段拆成差分的形式,然后可以用vector存一下每个时间点有哪些加入、删除。建树的时候先把rt[0]所对应的树完整建出来,然后对于每一个事件直接继承上一个时间然后在这时间对应的树修改就好了


  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. #define N 4000010
  4. #define LL long long
  5. struct Node{LL vl,typ;};
  6. LL cnt=0,tot=0,maxt=0,pre=1,b[N];
  7. LL rt[N],ls[N],rs[N],siz[N],sum[N];
  8. vector<Node> G[N];
  9. map<LL,LL> mp;
  10. LL read(){
  11. LL ans=0,w=1;char c=getchar();
  12. while(!isdigit(c)&&c!='-')c=getchar();
  13. if(c=='-')c=getchar(),w=-1;
  14. while(isdigit(c))ans=ans*10+c-'0',c=getchar();
  15. return ans*w;
  16. }
  17. void build(LL &t,LL l,LL r){
  18. if(l>r)return;
  19. t=++cnt;
  20. if(l==r)return;
  21. LL mid=(l+r)>>1;
  22. build(ls[t],l,mid);
  23. build(rs[t],mid+1,r);
  24. }
  25. void modify(LL &t,LL last,LL l,LL r,LL vl,LL pos,LL typ){
  26. t=++cnt;
  27. sum[t]=sum[last]+vl;
  28. siz[t]=siz[last]+typ;
  29. ls[t]=ls[last];
  30. rs[t]=rs[last];
  31. if(l==r)return;
  32. LL mid=(l+r)>>1;
  33. if(pos<=mid)modify(ls[t],ls[last],l,mid,vl,pos,typ);
  34. else modify(rs[t],rs[last],mid+1,r,vl,pos,typ);
  35. }
  36. LL query(LL t,LL l,LL r,LL k){
  37. if(k>=siz[t])return sum[t];
  38. if(l==r)return sum[t]/siz[t]*k;
  39. LL mid=(l+r)>>1,tmp=siz[ls[t]];
  40. if(k<=tmp)return query(ls[t],l,mid,k);
  41. else return query(rs[t],mid+1,r,k-tmp)+sum[ls[t]];
  42. }
  43. int main(){
  44. LL n=read(),m=read();
  45. for(LL i=1;i<=n;i++){
  46. LL s=read(),e=read(),p=read();
  47. b[i]=p;
  48. G[s].push_back((Node){p,1});
  49. G[e+1].push_back((Node){-p,-1});
  50. maxt=max(maxt,e+1);
  51. }
  52. sort(b+1,b+n+1);
  53. for(LL i=1;i<=n;i++)if(!mp[b[i]])mp[b[i]]=++tot;
  54. build(rt[0],1,tot);
  55. for(LL i=1;i<=maxt;i++){
  56. rt[i]=rt[i-1];
  57. for(LL j=0;j<G[i].size();j++)
  58. modify(rt[i],rt[i],1,tot,G[i][j].vl,mp[labs(G[i][j].vl)],G[i][j].typ);
  59. }
  60. for(LL i=1;i<=m;i++){
  61. LL x=read(),a=read(),b=read(),c=read(),k=(a*pre+b)%c+1;
  62. printf("%lld\n",pre=query(rt[x],1,tot,k));
  63. }
  64. return 0;
  65. }

BZOJ3932 CQOI2015 任务查询系统 【主席树】的更多相关文章

  1. BZOJ3932: [CQOI2015]任务查询系统 主席树

    3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 4869  Solved: 1652[Submit][St ...

  2. BZOJ3932[CQOI2015]任务查询系统——主席树

    题目描述 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第E ...

  3. BZOJ3932 CQOI2015 任务查询系统 - 主席树,离散化

    记录下自己写错的地方吧 1. 区间可能有重复 2. 没有出现的坐标也要计入version (因为询问里可能会有) #include <bits/stdc++.h> using namesp ...

  4. 【BZOJ3932】[CQOI2015]任务查询系统 主席树

    [BZOJ3932][CQOI2015]任务查询系统 Description 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si, ...

  5. [CQOI2015]任务查询系统 主席树

    [CQOI2015]任务查询系统 LG传送门 以前还没见过主席树的这种写法. 考虑使用差分的思想处理每一个任务,然后所有的东西就都能顺理成章地用主席树维护了,查询的时候和平时的主席树有一点不同,详见代 ...

  6. bzoj 3932: [CQOI2015]任务查询系统 -- 主席树 / 暴力

    3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec  Memory Limit: 512 MB Description 最近实验室正在为其管理的超级计算机编制一套任务管 ...

  7. 洛谷P3168 [CQOI2015]任务查询系统 [主席树,差分]

    题目传送门 任务查询系统 题目描述 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任 ...

  8. BZOJ 3932: [CQOI2015]任务查询系统 [主席树]

    传送门 题意: 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第Ei秒后结束(第Si秒和Ei秒任务也在运行),其优先级为Pi 调度系统会经常向查询系统询问,第Xi ...

  9. BZOJ.3932.[CQOI2015]任务查询系统(主席树 差分)

    题目链接 对于这一区间的操作,我们可以想到差分+前缀和(感觉也没什么别的了..). 同时对于本题我们能想到主席树,而主席树正是利用前一个节点建树的. 所以离散化.按时间排序,把操作拆成单点加和减即可. ...

  10. BZOJ 3932: [CQOI2015]任务查询系统 | 主席树练习题

    题目: 洛谷也能评测 题解: De了好长时间BUG发现是自己sort前面有一行for没删,气死. 题目询问第x秒时候前k小的P值之和. 朴素想法: 我们可以把P值离散化,然后对于每个时刻建一棵定义域是 ...

随机推荐

  1. ThinkPHP的URL重写时遇到No input file specified的解决方法

    因为在Fastcgi模式下,php不支持rewrite的目标网址的PATH_INFO的解析 ThinkPHP运行在URL_MODEL=2时,会出现 No input file specified.的情 ...

  2. zDialog弹出层插件

    效果图如下: 提取自ZCMS的弹出框: 代替window.open.window.alert.window.confirm:提供良好的用户体验: 水晶质感,设计细腻,外观漂亮: 兼容ie6/7/8.f ...

  3. Promise相关网址

    1.https://github.com/fsjohnhuang/iPromise 2.https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/ ...

  4. 转载:Mongodb start

    Mongodb 操作 Start MongoDB The MongoDB instance stores its data files in the /var/lib/mongo and its lo ...

  5. 最优比率生成树 poj2728

    Desert King Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 28407   Accepted: 7863 Desc ...

  6. 【Error】IOError: [Errno 22] invalid mode ('wb') or filename

    错误描述: IOError: [Errno 22] invalid mode ('wb') or filename: 'C:\\Users\\Viral Patel\\Documents\\GitHu ...

  7. ansible入门二(Ansible常见模块介绍)

    本节内容: ansible命令基础 常见模块举例 一.ansible命令基础 语法: ansible <host-pattern> [-f forks] [-m module_name] ...

  8. 使用Python自带的库和正则表达式爬取熊猫直播主播观看人气

    主要是体现代码的规范性 from urllib import request import re class Spider(): url = 'https://www.panda.tv/cate/lo ...

  9. EasyUI Combobox 组合框

    默认选择第一项,加请选择,取值问题 <input class="easyui-combobox" id="ddlWHS" name="ddlWH ...

  10. New Concept English three (23)

    31w 45 People become quite illogical when they try to decide what can be eaten and what cannot be ea ...