【题解】CQOI2015任务查询系统
主席树,操作上面基本上是一样的。每一个时间节点一棵树,一个树上的每个节点代表一个优先级的节点。把开始和结束时间点离散,在每一棵树上进行修改。注意因为一个时间节点可能会有多个修改,但我们要保证都在同一棵树上,所以我采取了让每个节点额外存储所属于的树的一个信息。当更新到一个节点的时候,如果属于建立好的新树,那么就修改;不属于,则重新建链。
但这题有一个地方需要注意,就是所求的个数有可能小于一个叶子结点中存储的任务个数,这时我们就要返回k * num。
代码(有的地方感觉自己写的有些啰嗦,大家看看就好):
// luogu-judger-enable-o2
#include <bits/stdc++.h>
using namespace std;
#define int long long
#define maxn 1500000
int n, m, timer, tot, cnt, sum, pre = , root[maxn], Ti[maxn];
map <int, int> Map;
bool vis[maxn];
struct node
{
int t, num;
}upd[maxn * ]; struct tree
{
int lson, rson, cal, root, size, rank;
}T[maxn * ]; struct project
{
int s, e, p;
}P[maxn]; bool cmp(project a, project b)
{
return a.p < b.p;
} bool cmp2(node a, node b)
{
return a.t < b.t;
} int read()
{
int x = , k = ;
char c;
c = getchar();
while(c < '' || c > '') { if(c == '-') k = -; c = getchar(); }
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * k;
} void update(int &now, int bf, int x, int num, int l, int r, int root)
{
if(root != T[now].root) now = ++ sum, T[now] = T[bf], T[now].root = root;
if(num > ) T[now].size += ;
else T[now].size -= ;
if(l == r)
{
T[now].cal += num;
T[now].rank = num;
return;
}
int mid = (l + r) >> ;
if(x <= mid) update(T[now].lson, T[bf].lson, x, num, l, mid, root);
else update(T[now].rson, T[bf].rson, x, num, mid + , r, root);
T[now].cal = T[T[now].lson].cal + T[T[now].rson].cal;
} int query(int now, int L, int R, int k)
{
int mid = (L + R) >> ;
int size = T[T[now].lson].size;
if(L == R) return k * T[now].rank;
if(k >= T[now].size) return T[now].cal;
if(k <= size) return query(T[now].lson, L, mid, k);
else return query(T[now].lson, L, mid, size) + query(T[now].rson, mid + , R, k - size);
} signed main()
{
m = read(), n = read();
for(int i = ; i <= m; i ++)
{
P[i].s = read(), P[i].e = read(), P[i].p = read();
upd[++ cnt] = (node) {P[i].s, P[i].p};
upd[++ cnt] = (node) {P[i].e + , -P[i].p};
}
sort(P + , P + + m, cmp);
for(int i = ; i <= m; i ++)
if(P[i].p != P[i - ].p) Map[P[i].p] = ++ tot;
sort(upd + , upd + + cnt, cmp2);
for(int i = ; i <= cnt; i ++)
{
if(upd[i].t != upd[i - ].t)
{
int now = ++ timer; Ti[upd[i].t] = now;
root[timer] = ++ sum;
int t = upd[i].t - ;
while(!Ti[t]) Ti[t] = now - , t --;
}
int t = Ti[upd[i].t];
update(root[t], root[t - ], Map[abs(upd[i].num)], upd[i].num, , tot, t);
vis[t] = true;
}
for(int i = ; i <= n; i ++)
{
int x = read(), a = read(), b = read(), c = read();
int ans, k = + (a * pre + b) % c;
printf("%lld\n", ans = query(root[Ti[x]], , tot, k));
pre = ans;
}
return ;
}
【题解】CQOI2015任务查询系统的更多相关文章
- 题解 [CQOI2015]任务查询系统
题面 解析 首先,我们考虑下暴力的做法: 每次将一个任务的重要度加入到它的区间中, 询问的时候就直接加前\(k\)大. 然而,这样肯会炸的(都说了是暴力了). 其实,我们可以转化一下区间修改(因为区间 ...
- BZOJ3932: [CQOI2015]任务查询系统 主席树
3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 4869 Solved: 1652[Submit][St ...
- 主席树||可持久化线段树||离散化||[CQOI2015]任务查询系统||BZOJ 3932||Luogu P3168
题目: [CQOI2015]任务查询系统 题解: 是一道很经典的题目.大体思路是抓优先级来当下标做主席树,用时刻作为主席树的版本.然而优先级范围到1e7去了,就离散化一遍.然后把每个事件的开始(s). ...
- 【BZOJ3932】[CQOI2015]任务查询系统 主席树
[BZOJ3932][CQOI2015]任务查询系统 Description 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si, ...
- BZOJ_3932_[CQOI2015]任务查询系统_主席树
BZOJ_3932_[CQOI2015]任务查询系统_主席树 题意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,P ...
- P3168 [CQOI2015]任务查询系统
题目地址:P3168 [CQOI2015]任务查询系统 主席树的模板题 更模板的在这儿:P3834 [模板]可持久化线段树 1(主席树) 形象的说,P3834是"单点修改,区间查询" ...
- bzoj3932 / P3168 [CQOI2015]任务查询系统(主席树+差分)
P3168 [CQOI2015]任务查询系统 看到第k小,就是主席树辣 对于每一段任务(a,b,k),在版本a的主席树+k,版本b+1的主席树-k 同一时间可能有多次修改,所以开个vector存操作, ...
- 2018.06.30 BZOJ 3932: [CQOI2015]任务查询系统(主席树)
3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec Memory Limit: 512 MB Description 最近实验室正在为其管理的超级计算机编制一套任务管理 ...
- [CQOI2015]任务查询系统 主席树
[CQOI2015]任务查询系统 LG传送门 以前还没见过主席树的这种写法. 考虑使用差分的思想处理每一个任务,然后所有的东西就都能顺理成章地用主席树维护了,查询的时候和平时的主席树有一点不同,详见代 ...
- bzoj 3932: [CQOI2015]任务查询系统 -- 主席树 / 暴力
3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec Memory Limit: 512 MB Description 最近实验室正在为其管理的超级计算机编制一套任务管 ...
随机推荐
- Apache Maven(七):settings.xml
settings.xml 文件中包含settings标签,这个标签可以配置如何去执行Maven.其中包括本地存储库位置,备用远程存储库服务器和身份验证信息等值. 有如下两个位置可能存放这setting ...
- Centos6.5 安装python2.7.14
2018-06-30 因为Centos6.5系统默认使用,python2.6.6.最近在学python.老师推荐将2.6.6升级至2.7.14.所以以留此文,怕哪天脑子短路好回来看看... >1 ...
- go学习笔记-变量作用域
变量作用域 作用域为已声明标识符所表示的常量.类型.变量.函数或包在源代码中的作用范围. 变量可以在三个地方声明: 函数内定义的变量称为局部变量 函数外定义的变量称为全局变量 函数定义中的变量称为形式 ...
- JAVA学习一 对象数组
对象数组 今天在写一个代码,才发现自己对于对象数组的理解是不够的,那么就讲讲自己现在的理解. 对于数组中的每一个元素都是一个针对对象的引用 他会指向你的具体的一个堆上的对象,它本身知识一个地址值,与其 ...
- 集成运放输入电压范围指标参数Uicmax,Uidmax
图中Uicmax最大共模输入电压:是运放能正常工作下的最大输入电压: Uidmax最大差模输入电压:是运放要损坏的最大输入电压
- c++实验3类和对象
实 验 3: part 1:验证 part 2:graph #include <iostream> #include "graph.h" using namespac ...
- 2018春季校园招聘笔经面经合集:Java开发岗
2018春季校园招聘笔经面经合集:Java开发岗 以下为精选面经: 美团外卖配送部后台开发面经 nowcoder.com/discuss/76 春招总结,干货满满 nowcoder.com/discu ...
- Linux设定IP地址
下面这些内容是直接从其他地方扒拉过来的,后期根据自己使用情况修改补充 虚拟机的连接方式 1.NAT(网络地址转换,虚拟机可以上网,但不能和物理机通信)-----VMnet82.host only(主机 ...
- Java并发(多线程)
一.多线程的基本概念 1.什么是进程.多进程有什么作用? 大家都使用计算机,当我们打开某一个软件的时候,其实就是启动了一个进程,可以打开任务管理器看看,我们打开的每一个软件,都是一个进程,在同一个操作 ...
- Qt 在控件上面绘图 label,pushbutton。。。。。
最近有点时间,就研究研究Qt ,提升一下自己 我记得我在刚开始学习Qt 的时候,想要在一个控件上面绘制图形,那就要构建一个新类来调用该控件的绘图函数 今天看到了狗哥的学习博客,感觉自己好渺小啊,按照狗 ...