【LG4585】[FJOI2015]火星商店问题

题面

bzoj权限题

洛谷

\(Notice:\)

关于题面的几个比较坑的地方:

  • “一天”不是一个操作,而是有0操作就相当于一天开始了,然后下面的紧跟着的1操作都算这一天的,直到再次出现0操作为止。当然第一个操作可能会是1操作这个时候也算第一天(比如样例……)

  • 0操作是在这个位置添加一个数而不是改成这个数

  • d=0的时候不算这一天

垃圾题面,害我被坑

题解

显然对于每个人他的可购买商品的时间都是一个区间。

这样我们按照线段树分治的套路在线段树上打一个那个人的标

记。

我们将所有操作离线, 并将修改和询问分开存下来。

对于每一个修改, 我们按照其在线段树上分治, 存下当前区间所

对应的修改序列, 这个过程可以像整体二分那样处理。

将这段区间内的修改建可持久化\(\text{Trie}\), 而且此时这个时间范围内

的询问你是知道的, 直接在\(\text{Trie}\)上查即可。

代码

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <vector>
using namespace std;
inline int gi() {
register int data = 0, w = 1;
register char ch = 0;
while (!isdigit(ch) && ch != '-') ch = getchar();
if (ch == '-') w = -1, ch = getchar();
while (isdigit(ch)) data = 10 * data + ch - '0', ch = getchar();
return w * data;
}
const int MAX_N = 1e5 + 5;
namespace Trie {
struct Trie { int ch[2], v; } t[MAX_N << 5]; int tot, rt[MAX_N];
void insert(int &o, int p, int v, int i) {
o = ++tot, t[o] = t[p], ++t[o].v;
if (i == -1) return ;
bool c = (v >> i) & 1;
insert(t[o].ch[c], t[p].ch[c], v, i - 1);
}
int query(int v, int u, int w, int i) {
if (i == -1) return 0;
bool c = (w >> i) & 1;
int res = t[t[u].ch[c ^ 1]].v - t[t[v].ch[c ^ 1]].v;
if (res) return query(t[v].ch[c ^ 1], t[u].ch[c ^ 1], w, i - 1) + (1 << i);
else return query(t[v].ch[c], t[u].ch[c], w, i - 1);
}
}
struct Mdy { int s, v, t; } q[MAX_N], lq[MAX_N], rq[MAX_N];
bool operator < (const Mdy &l, const Mdy &r) { return l.s < r.s; }
struct Qry { int l, r, tl, tr, v; } p[MAX_N];
int m_cnt, q_cnt;
int N, M, ans[MAX_N];
#define lson (o << 1)
#define rson (o << 1 | 1)
vector<int> vec[MAX_N << 2];
void modify(int o, int l, int r, int ql, int qr, int pos) {
if (ql > qr) return ;
if (ql <= l && r <= qr) return (void)vec[o].push_back(pos);
int mid = (l + r) >> 1;
if (ql <= mid) modify(lson, l, mid, ql, qr, pos);
if (qr > mid) modify(rson, mid + 1, r, ql, qr, pos);
}
int stk[MAX_N], top;
void calc(int o, int l, int r) {
top = Trie::tot = 0;
for (int i = l; i <= r; i++) {
stk[++top] = q[i].s;
Trie::insert(Trie::rt[top], Trie::rt[top - 1], q[i].v, 17);
}
for (vector<int>::iterator ite = vec[o].begin(); ite != vec[o].end(); ++ite) {
int k = *ite;
int l = upper_bound(&stk[1], &stk[top + 1], p[k].l - 1) - stk - 1;
int r = upper_bound(&stk[1], &stk[top + 1], p[k].r) - stk - 1;
ans[k] = max(ans[k], Trie::query(Trie::rt[l], Trie::rt[r], p[k].v, 17));
}
}
void Div(int o, int lval, int rval, int st, int ed) {
if (st > ed) return ;
calc(o, st, ed);
if (lval == rval) return ;
int mid = (lval + rval) >> 1, lt = 0, rt = 0;
for (int i = st; i <= ed; i++)
if (q[i].t <= mid) lq[++lt] = q[i];
else rq[++rt] = q[i];
for (int i = 1; i <= lt; i++) q[st + i - 1] = lq[i];
for (int i = 1; i <= rt; i++) q[st + lt + i - 1] = rq[i];
Div(lson, lval, mid, st, st + lt - 1);
Div(rson, mid + 1, rval, st + lt, ed);
} int main () {
N = gi(), M = gi();
for (int i = 1; i <= N; i++) Trie::insert(Trie::rt[i], Trie::rt[i - 1], gi(), 17);
for (int i = 1; i <= M; i++) {
int op = gi();
if (op == 0) { int s = gi(), v = gi(); q[++m_cnt] = (Mdy){s, v, m_cnt}; }
else {
int l = gi(), r = gi(), v = gi(), d = gi();
p[++q_cnt] = (Qry){l, r, max(1, m_cnt - d + 1), m_cnt, v};
ans[q_cnt] = Trie::query(Trie::rt[l - 1], Trie::rt[r], v, 17);
}
}
for (int i = 1; i <= q_cnt; i++) modify(1, 1, m_cnt, p[i].tl, p[i].tr, i);
sort(&q[1], &q[m_cnt + 1]);
Div(1, 1, m_cnt, 1, m_cnt);
for (int i = 1; i <= q_cnt; i++) printf("%d\n", ans[i]);
return 0;
}

【LG4585】[FJOI2015]火星商店问题的更多相关文章

  1. [FJOI2015]火星商店问题

    [FJOI2015]火星商店问题 神仙线段树分治...不过我不会. 这题用线段树套可持久化Trie还是能写的. 常数有点大,洛谷垫底水平. // luogu-judger-enable-o2 #inc ...

  2. 洛谷 P4585 [FJOI2015]火星商店问题 解题报告

    P4585 [FJOI2015]火星商店问题 题目描述 火星上的一条商业街里按照商店的编号\(1,2,\dots,n\) ,依次排列着\(n\)个商店.商店里出售的琳琅满目的商品中,每种商品都用一个非 ...

  3. [FJOI2015]火星商店问题(线段树分治,可持久化,Trie树)

    [FJOI2015]火星商店问题 前天考了到线段树分治模板题,全场都切了,就我不会QAQ 于是切题无数的Tyher巨巨就告诉我:"你可以去看看火星商店问题,看了你就会了." 第一道 ...

  4. 【题解】P4585 [FJOI2015]火星商店问题(线段树套Trie树)

    [题解]P4585 [FJOI2015]火星商店问题(线段树套Trie树) 语文没学好不要写省选题面!!!! 题目大意: 有\(n\)个集合,每个集合有个任意时刻都可用的初始元素.现在有\(m\)个操 ...

  5. [FJOI2015]火星商店问题(分治+可持久化)

    题目描述 火星上的一条商业街里按照商店的编号1,2 ,…,n ,依次排列着n个商店.商店里出售的琳琅满目的商品中,每种商品都用一个非负整数val来标价.每个商店每天都有可能进一些新商品,其标价可能与已 ...

  6. BZOJ4137 & 洛谷4585:[FJOI2015]火星商店问题

    https://www.lydsy.com/JudgeOnline/problem.php?id=4137 https://www.luogu.org/problemnew/show/P4585 火星 ...

  7. 【bzoj4137】[FJOI2015]火星商店问题

    *题目描述: 火星上的一条商业街里按照商店的编号1,2 ,…,n ,依次排列着n个商店.商店里出售的琳琅满目的商品中,每种商品都用一个非负整数val来标价.每个商店每天都有可能进一些新商品,其标价可能 ...

  8. [洛谷P4585] [FJOI2015] 火星商店问题

    Description 火星上的一条商业街里按照商店的编号 \(1\),\(2\) ,-,\(n\) ,依次排列着 \(n\) 个商店.商店里出售的琳琅满目的商品中,每种商品都用一个非负整数 \(va ...

  9. 2019.01.13 bzoj4137: [FJOI2015]火星商店问题(线段树分治+可持久化01trie)

    传送门 题意:序列上有nnn个商店,有两种事件会发生: sss商店上进购标价为vvv的一个物品 求编号为[l,r][l,r][l,r]之间的位置买ddd天内新进购的所有物品与一个数xxx异或值的最大值 ...

随机推荐

  1. tomcat多实例.md

    多tomcat实例 环境说明 操作系统:CentOS 6.6 JDK: # ll /usr/local/java lrwxrwxrwx 1 root root 22 Feb 27 17:43 /usr ...

  2. 问题:alias设置与删除

    新建alias条目 临时 alias  monitor='gnome-system-monitor' 永久 可以在家目录下,新建    .bash_aliases 文件,然后在其中加上你想要的替换的比 ...

  3. 程序人生:02我来告诉你,一个草根程序员如何进入BAT

    本文摘自左潇龙博客,原文出处:http://www.cnblogs.com/zuoxiaolong/p/life54.html 引言 首先声明,不要再问LZ谁是林萧,林萧就是某著名程序员小说的主角名字 ...

  4. Python 多线程 使用线程 (二)

    Python中实现多线程需要使用到 threading 库,其中每一个 Thread类 的实例控制一个线程. Thread类 #类签名 def __init__(self, group=None, t ...

  5. PHP面试系列 之Linux(五)---- 案例

    题:如何实现每天0点重新启动服务器? 答: (1)创建定时任务,并进行编辑 crontab -e (2)编写脚本内容 * * * reboot 0分  0时  每日  每月  每周 执行的命令:reb ...

  6. 【题解】洛谷P1080 [NOIP2012TG] 国王游戏(贪心+高精度)

    次元传送门::洛谷P1080 思路 我们模拟一下只有两个大臣的时候发现 当a1​∗b1​<a2​∗b2​是ans1<ans2 所以我们对所有大臣关于左右手之积进行排序 得到最多钱的大臣就是 ...

  7. cocos2d-x开发: 如何从项目中分离出接口范例

    cocos2d-x开发,包括核心模块接口开发和脚本部分的业务逻辑实现.从上层应用需求开始说,脚本在做业务逻辑实现的时候, 很多时候都需要依赖底层的接口功能,但是不是所有的人都可以游刃有余的去明白该怎么 ...

  8. Kafka 部署指南-好久没有更新博客了

    最近到了一家新公司,很多全新技术栈要理解.每天都在看各类 English Offcial Document,我的宗旨是我既然看懂了,就写下来分享,这是第一篇. 基本需求: 1.已有 zookeeper ...

  9. JQ+css3 导航栏到底部上移

    导航栏 .navigation { position: fixed; bottom: 100px; right: 100px; z-index:; } .navigation { transition ...

  10. java8时间工具类Localdate、LocaldateTime

    优点: 1.方便. Date 只能是日期加时间的格式,而 LocalDate .LocalTime.LocalDateTime 分别代表日期,时间,日期+时间,非常灵活.再就是后者在日期计算及格式化方 ...