bzoj3932 任务查询系统

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行,每行一个整数,表示查询结果。

优先级离散化后,按时间顺序向可持久化线段树插入/删除任务的优先级,同时维护子树中任务个数。

#include<cstdio>
#include<algorithm>
typedef long long lint;
const int N=20000000,mx=131072;
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[200005];
int opp=0;
int vs[100005],vp=0;
int lc[N],rc[N],sz[N];
lint sum[N];
int rts[100005];
int p=1;
lint get(int w,int x,int L,int R){
    //printf("g[%d,%d] x:%d\n",L,R,x);
    int M=L+R>>1;
    if(sz[w]<=x)return sum[w];
    if(L==R)return vs[L-1]*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+1,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]+1;
            sum[u]=sum[w]+v;
        }else{
            sz[u]=sz[w]-1;
            sum[u]=sum[w]-v;
        }
        lc[u]=rc[u]=0;
    }else{
        int M=L+R>>1;
        if(x>M){
            rc[u]=add(rc[w],v,s,x,M+1,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>>1;
    if(L<R){
        lc[w]=build(L,M);
        rc[w]=build(M+1,R);
    }
    sz[w]=sum[w]=0;
    return w;
}
int main(){
    int a,b,c,x;
    lint pre=1ll;
    scanf("%d%d",&m,&n);
    for(int i=0;i<m;i++){
        scanf("%d%d%d",&a,&b,&c);
        ops[opp++]=op(a,c,1);
        ops[opp++]=op(b+1,c,0);
        vs[vp++]=c;
    }
    std::sort(ops,ops+opp);
    std::sort(vs,vs+vp);
    int vm=vp;vp=1;
    for(int i=1;i<vm;i++)if(vs[i]>vs[i-1])vs[vp++]=vs[i];
    rts[0]=build(1,mx);
    for(int i=1,oi=0;i<=n;i++){
        rts[i]=rts[i-1];
        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,1,mx);
            oi++;
        }
    }
    for(int i=1;i<=n;i++){
        scanf("%d%d%d%d",&x,&a,&b,&c);
        pre=get(rts[x],(a*pre%c+b)%c+1,1,mx);
        printf("%lld\n",pre);
    }
    return 0;
}
时间: 2024-08-25 12:06:33

bzoj3932 任务查询系统的相关文章

3932: [CQOI2015]任务查询系统

3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 2559  Solved: 819[Submit][Status][Discuss] Description 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第Ei秒后结束(第Si秒和Ei秒任务也在运行 ),其优先级为P

任务查询系统-暴力(数据怎么这么弱)

传送门:任务查询系统 3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 2815  Solved: 899 Description 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第Ei秒后结束(第Si秒和Ei秒任务也在运行 ),其优先级为Pi.同一时间可能有多个任务同

LibreOJ2097 - 「CQOI2015」任务查询系统

Portal Description 给出\(n(n\leq10^5)\)个任务,和总时间范围\(m(m\leq10^5)\).每个任务有开始/结束时间\(s_i,e_i(1\leq s_i \leq e_i \leq m)\)和优先级\(p_i(p_i\leq10^9)\).接下来\(m\)个询问,每次询问在时刻\(t_i\)时优先级前\(k\)大的任务的优先级之和,若\(k\)大于此时正在进行的任务总数则输出此时优先级之和.其中\(\{t_m\}\)是\(1..m\)的一个排列. Solut

「CQOI2015」任务查询系统

「CQOI2015」任务查询系统 传送门 好像也是板子题??? 区间修改,单点查询,考虑差分. 然后每次查询时就直接在对应的主席树上二分即可. 参考代码: #include <cstdio> #include <vector> #define rg register #define file(x) freopen(x".in", "r", stdin), freopen(x".out", "w", st

[bzoj3932][CQOI2015]任务查询系统-题解[主席树][权值线段树]

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

[bzoj3932][CQOI2015][任务查询系统] (主席树)

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

【bzoj3932】 CQOI2015—任务查询系统

http://www.lydsy.com/JudgeOnline/problem.php?id=3932 (题目链接) 题意 给出$m$个区间,每个区间有一个权值,$n$组询问,每次询问在位置$x$权值前$k$大的区间的权值和. Solution 扫描线搞一下然后主席树维护即可. 细节 查询的时候注意叶子节的情况 代码 // bzoj3932 #include<algorithm> #include<iostream> #include<cstdlib> #includ

BZOJ3932:[CQOI2015]任务查询系统——题解

http://www.lydsy.com/JudgeOnline/problem.php?id=3932 题面源于洛谷 题目描述 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第Ei秒后结束(第Si秒和Ei秒任务也在运行),其优先级为Pi.同一时间可能有多个任务同时执行,它们的优先级可能相同,也可能不同.调度系统会经常向查询系统询问,第Xi秒正在运行的任务中,

BZOJ3932: [CQOI2015]任务查询系统

传送门 真不知道我没学主席树之前是有什么勇气说自己高级数据结构以及学的七七八八了. 这道题应该也是算是主席树的经典运用. 刚开始脑抽了,想把(S,E,P)的处理直接在线用树状数组xjb搞搞算了.写完后才意识到树状数组无法(很难?)实现区间修改. 然后想了想既然这个是一下子把所有修改都放上了直接用树状数组差分一下不就好了! 然后又深感自己制杖,为什么要用树状数组差分呢,直接开几个vector维护一下就行了. 说是修改,本质上是不带修改的主席树,很快搞完.WA,眼查,无果,跟踪,无果. 拍了几组小数