BZOJ 3932 [CQOI2015]任务查询系统 ——可持久化线段树
【题目分析】
主席树,维护区间大小以及权值之和。
但是细节确实要琢磨很久,WA了几次。
【代码】
#include <cstdio> #include <cstring> #include <cstdlib> #include <cmath> #include <set> #include <map> #include <string> #include <algorithm> #include <vector> #include <iostream> #include <queue> using namespace std; #define maxn 300005 #define mlog 40 #define inf (0x3f3f3f3f) #define ll long long 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; } ll llread() { 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; } ll rt[maxn],ls[maxn*mlog],rs[maxn*mlog],siz[maxn*mlog],tot=0,n,m; struct eve{ll p,opt;}a[maxn]; vector <eve> v[maxn]; ll sum[maxn*mlog]; ll b[maxn],top=0,cnt=0; ll pre=1; /* void ins(ll o1,ll &o2,ll l,ll r,ll x,ll f) { o2=++tot; siz[o2]=siz[o1]+f; sum[o2]=sum[o2]+(ll)b[x]*f; if (l==r) return ; ll mid=(l+r)/2; if (x<=mid) ins(ls[o1],ls[o2],1,mid,x,f),rs[o2]=rs[o1]; else ins(rs[o1],rs[o2],mid+1,r,x,f),ls[o2]=ls[o1]; // sum[o2]=sum[ls[o1]]+sum[ls[o2]]; } */ ll ins (ll o1,ll l,ll r,ll x,ll f) { ll now=++tot; siz[now]=siz[o1]+f; sum[now]=sum[o1]+b[x]*f; if (l==r) return now; ll mid=(l+r)/2; if (x<=mid) ls[now]=ins(ls[o1],l,mid,x,f),rs[now]=rs[o1]; else rs[now]=ins(rs[o1],mid+1,r,x,f),ls[now]=ls[o1]; return now; } ll query(ll o,ll l,ll r,ll x) { if (x>=siz[o]) return sum[o]; if (l==r) return min(x,siz[o])*b[l]; ll tmp=siz[ls[o]]; if (tmp>=x) return query(ls[o],l,(l+r)/2,x); else return sum[ls[o]]+query(rs[o],(l+r)/2+1,r,x-tmp); } int main() { n=read();m=read(); for (ll i=1;i<=n;++i) { ll x=read(),y=read(),z=read(); if (x<=m) { a[++cnt].p=z; a[cnt].opt=1; v[x].push_back(a[cnt]); } if (y+1<=m) { a[++cnt].p=z; a[cnt].opt=-1; v[y+1].push_back(a[cnt]); } b[++top]=z; } sort(b+1,b+top+1); top=unique(b+1,b+top+1)-b-1; for (ll i=1;i<=m;++i) { rt[i]=rt[i-1]; for (ll j=0;j<v[i].size();++j) rt[i]=ins(rt[i],1,top,lower_bound(b+1,b+top+1,v[i][j].p)-b,v[i][j].opt); } for (ll i=1;i<=m;++i) { ll k,x,a,b,c; x=llread();a=llread();b=llread();c=llread(); k=1+(a*pre+b)%c; // if (i==m) k++; printf("%lld\n",pre=query(rt[x],1,top,k)); } }
BZOJ 3932 [CQOI2015]任务查询系统 ——可持久化线段树的更多相关文章
- 2018.06.30 BZOJ 3932: [CQOI2015]任务查询系统(主席树)
3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec Memory Limit: 512 MB Description 最近实验室正在为其管理的超级计算机编制一套任务管理 ...
- bzoj 3932: [CQOI2015]任务查询系统 -- 主席树 / 暴力
3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec Memory Limit: 512 MB Description 最近实验室正在为其管理的超级计算机编制一套任务管 ...
- bzoj 3932 [CQOI2015]任务查询系统(主席树)
Description 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分. 超级计算机中的任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si ...
- bzoj 3932: [CQOI2015]任务查询系统
Description 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si ...
- 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值离散化,然后对于每个时刻建一棵定义域是 ...
- BZOJ 3932 [CQOI2015]任务查询系统 - 差分 + 主席树
Solution 差分就好了, 在$s_i$ 的点+1, $e_i + 1$ 的点 - 1. 查询的时候注意$l == r$ 要返回 $k * b[l]$ ,而不是$sum[node] $因为当前位置 ...
- BZOJ 3932: [CQOI2015]任务查询系统 (主席树板题)
就是裸的主席树,差分之后排序插入主席树就行了. 注意主席树查询的时候叶子节点要特判,因为本身是有size的 还有要开longlong CODE #include <cctype> #inc ...
随机推荐
- 【linux】vim的一些快捷键
ctrl+y :重复上一行内容 v+移动光标 :选择内容 y :复制选中的内容 p :在光标处粘贴复制的内容 ctrl+v :进入列模式,可以选择多列数据 dd :剪切一行,也可做删除一行使用
- svn 默认忽略静态库 .a文件解决办法
我也是在向SVN服务器上传文件时,遇到了这个问题,文件上传后,再下载后发现所有的.a文件全部丢失,后来才知道是上传文件的时候.a文件根本就没传上去,查找原因才知道上传的时候.a文件被过滤掉了,后来找到 ...
- Jquery获取select 控件的change事件时选中的值
HTML代码如下: <div class="col-sm-9 col-xs-12"> <select id="groupid" class=& ...
- UISrollView
1. contentOffset 默认CGPointZero,用来设置scrollView的滚动偏移量. // 设置scrollView的滚动偏移量 scrollView.contentOffset ...
- 一个.xib界面文件中设计有多个View
一个新建的.xib文件(Xcode's Interface Builder),有一个默认的View,也就是self.view,是主视图 其他新建的View可以在viewDidLoad()函数中使用 [ ...
- VB.NET 注册表基本操作
''' <summary> ''' 注册表设置值 ''' </summary> ''' <param name="strKey"></pa ...
- 128. Longest Consecutive Sequence(leetcode)
Given an unsorted array of integers, find the length of the longest consecutive elements sequence. F ...
- Android开发环境搭建:离线安装ADT插件和安装SDK
一.准备 在线安装SDK较慢,在此我选择了离线安装,所需要的工具下载:http://yun.baidu.com/share/link?shareid=2286446004&uk=2000812 ...
- 关于快捷键 Ctrl+Alt+[方向键] 的知识
在用PS作图时使用 Ctrl+Alt+[方向键] 组合建时屏幕莫名翻转, 平时电脑懒得维护所以略卡,我不会说一般早上起床摁了开机去上完厕所回来还--咳咳 刚按下时瞬间一黑,再黑,,继续黑--真是大吃 ...
- MVC – 8.Razor 布局
8.1.@RenderBody() 8.2.多个"占位符":@RenderSection() 8.3.js合并 @Scripts.Render("~/bundles/js ...