●洛谷P3168 [CQOI2015]任务查询系统
题链:
https://www.luogu.org/problemnew/show/P3168
题解:
主席树
强制在线?
那就直接对每一个前缀时间建一个线段树(可持久化线段树),线段树维护优先度权值。
代码:
#include<bits/stdc++.h>
#define MAXN 100005
using namespace std;
int tmp[MAXN];
int N,M,tnt;
long long pre=1;
struct Event{
int ent;
int p[MAXN*2],k[MAXN*2],nxt[MAXN*2],head[MAXN];
Event():ent(2){}
void Add(int _t,int _p,int _k){
p[ent]=_p; k[ent]=_k; nxt[ent]=head[_t]; head[_t]=ent++;
}
}E;
struct SGT{//可持久化线段树(主席树),单修,区查???
int idnt,root[MAXN];
int ls[MAXN*18*2],rs[MAXN*18*2],size[MAXN*18*2];
long long sum[MAXN*18*2];
void Pushup(int u){
size[u]=size[ls[u]]+size[rs[u]];
sum[u]=sum[ls[u]]+sum[rs[u]];
}
void Modify(int v,int &u,int l,int r,int p,int k){
u=++idnt; ls[u]=ls[v]; rs[u]=rs[v]; sum[u]=sum[v]; size[u]=size[v];
if(l==r) return (void)(sum[u]+=k*tmp[l],size[u]+=k);
int mid=(l+r)>>1;
if(p<=mid) Modify(ls[v],ls[u],l,mid,p,k);
else Modify(rs[v],rs[u],mid+1,r,p,k);
Pushup(u);
}
long long Query(int u,int l,int r,int k){//先特判k是否太大
if(l==r){return 1ll*k*tmp[l];}
int mid=(l+r)>>1;
if(size[ls[u]]>=k) return Query(ls[u],l,mid,k);
long long ret=sum[ls[u]];
ret+=Query(rs[u],mid+1,r,k-size[ls[u]]);
return ret;
}
}DT;
int main(){
scanf("%d%d",&M,&N);
int a,b,c,x,k;
for(int i=1;i<=M;i++){
scanf("%d%d%d",&a,&b,&c);
E.Add(a,c,1); E.Add(b+1,c,-1);
tmp[++tnt]=c;
}
sort(tmp+1,tmp+tnt+1);
tnt=unique(tmp+1,tmp+tnt+1)-tmp-1;
for(int i=1,last=0;i<=N;i++){
DT.root[i]=last;
for(int e=E.head[i];e;e=E.nxt[e]){
E.p[e]=lower_bound(tmp+1,tmp+tnt+1,E.p[e])-tmp;
DT.Modify(last,DT.root[i],1,tnt,E.p[e],E.k[e]);
last=DT.root[i];
}
}
for(int i=1;i<=N;i++){
scanf("%d%d%d%d",&x,&a,&b,&c);
k=1+(a*pre+b)%c;//*/scanf("%d%d",&x,&k);
if(DT.size[DT.root[x]]<=k) pre=DT.sum[DT.root[x]];
else pre=DT.Query(DT.root[x],1,tnt,k);
printf("%lld\n",pre);
}
return 0;
}
●洛谷P3168 [CQOI2015]任务查询系统的更多相关文章
- 洛谷 P3168 [CQOI2015]任务查询系统 解题报告
P3168 [CQOI2015]任务查询系统 题目描述 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分. 超级计算机中的任务用三元组\((S_i,E_i,P_i) ...
- 洛谷P3168 [CQOI2015]任务查询系统 [主席树,差分]
题目传送门 任务查询系统 题目描述 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任 ...
- 洛谷P3168 [CQOI2015]任务查询系统
#include<cstdio> #include<cstdlib> #include<algorithm> #include<cstring> #in ...
- P3168 [CQOI2015]任务查询系统
题目地址:P3168 [CQOI2015]任务查询系统 主席树的模板题 更模板的在这儿:P3834 [模板]可持久化线段树 1(主席树) 形象的说,P3834是"单点修改,区间查询" ...
- bzoj3932 / P3168 [CQOI2015]任务查询系统(主席树+差分)
P3168 [CQOI2015]任务查询系统 看到第k小,就是主席树辣 对于每一段任务(a,b,k),在版本a的主席树+k,版本b+1的主席树-k 同一时间可能有多次修改,所以开个vector存操作, ...
- 洛谷$P$3168 任务查询系统 $[CQOI2015]$ 主席树
正解:主席树 解题报告: 传送门! 首先考虑如果是单点修改,那就是个线段树板子嘛$QwQ$ 然后现在是区间修改,对于区间修改,显然就考虑差分下,就变成单点修改辣$QwQ$ 同时单点查询前$k$小也就变 ...
- P3168 [CQOI2015]任务查询系统(主席树)
题目描述 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第Ei ...
- Luogu P3168 [CQOI2015]任务查询系统
题目链接 \(Click\) \(Here\) 差分主席树,就是把主席树做成一个差分前缀和的形式,还是很容易想到的. 写主席树的时候几个注意点: 查询可能开始于所有任务之前,二分任务点要把左边界设置为 ...
- p3168 [CQOI2015]任务查询系统(差分+主席树)
恕我才学浅薄,一开始想到的是树状数组+线段树,然后看了题解才第一次见到了差分这种神奇的科技 仔细想想,主席树的本质不就是前缀和嘛,加上一个差分也是可以的,没想到真是罪过罪过 对时间维护一个差分 在Si ...
随机推荐
- NetFPGA-1G-CML从零开始环境配置
NetFPGA-1G-CML从零开始环境配置 前言 偶得一块NetFPGA-1G-CML,跟着github对NetFPGA-1G-CML的入门指南,一步步把配置环境终于搭建起来,下面重新复现一下此过程 ...
- HP DL380服务器RAID信息丢失数据恢复方法和数据恢复过程分享
[数据恢复故障描述] 客户服务器属于HP品牌DL380系列,存储是由6块73GB SAS硬盘组成的RAID5,操作系统是WINDOWS 2003 SERVER,主要作为企业部门内部的文件服务器来 ...
- mycat入门_介绍与安装
利用闲暇时间接触了下mycat. 一.介绍 1.概述: 国内最活跃的.性能最好的开源数据库中间件,可以理解为数据库和应用层之间的一个代理组件. 2.作用: 读写分离.分表分库.主从切换. 3.原理: ...
- zookeeper入门系列:概述
zookeeper可谓是目前使用最广泛的分布式组件了.其功能和职责单一,但却非常重要. 在现今这个年代,介绍zookeeper的书和文章可谓多如牛毛,本人不才,试图通过自己的理解来介绍zookeepe ...
- MySQL中使用sql语句获得表结构
最近在研究PHP,那么就必须涉及到mysql.其中一个功能通过表数据自动生成页面,紧接着发现在一张空表中无法读取数据(因为人家刚刚新建,就是空的没有数据) 延伸出来便是直接查表结构获得字段名,再进行处 ...
- shiro中CacheManager相关的类结构介绍,提供redis Cache实现
cacheManager主要用于对shiro中的session.realm中的认证信息.授权信息进行缓存. 1.类结构 2.接口及类介绍 CacheManager 提供根据名字获取cache的作用. ...
- Python/MySQL(二、表操作以及连接)
Python/MySQL(二.表操作以及连接) mysql表操作: 主键:一个表只能有一个主键.主键可以由多列组成. 外键 :可以进行联合外键,操作. mysql> create table y ...
- Struts(二十三):使用声名式验证
Struts2工程中的验证分为两种: 1.基于XWork Validation Framework的声明式验证:Struts2提供了一些基于XWork Validation Framework的内建验 ...
- 确定稳定的 Spring Cloud 相关环境版本
开发部署 Spring Cloud 微服务框架,需要先确定 Spring Cloud 的相关环境版本,主要包含:Spring Cloud.Spring Cloud Netflix.JDK.JRE.Ja ...
- Oracle服务启动项
七个服务的含义分别为: 1. Oracle ORCL VSS Writer Service: Oracle卷映射拷贝写入服务,VSS(Volume Shadow Copy Service)能够让存储基 ...