BZOJ4571: [Scoi2016]美味【主席树】【贪心】
Description
一家餐厅有 n 道菜,编号 1...n ,大家对第 i 道菜的评价值为 ai(1≤i≤n)。有 m 位顾客,第 i 位顾客的期
望值为 bi,而他的偏好值为 xi 。因此,第 i 位顾客认为第 j 道菜的美味度为 bi XOR (aj+xi),XOR 表示异或
运算。第 i 位顾客希望从这些菜中挑出他认为最美味的菜,即美味值最大的菜,但由于价格等因素,他只能从第
li 道到第 ri 道中选择。请你帮助他们找出最美味的菜。
Input
第1行,两个整数,n,m,表示菜品数和顾客数。
第2行,n个整数,a1,a2,...,an,表示每道菜的评价值。
第3至m+2行,每行4个整数,b,x,l,r,表示该位顾客的期望值,偏好值,和可以选择菜品区间。
\(1≤n≤2×10^5,0≤ai,bi,xi<10^5,1≤li≤ri≤n(1≤i≤m);1≤m≤10^5\)
Output
输出 m 行,每行 1 个整数,ymax ,表示该位顾客选择的最美味的菜的美味值。
Sample Input
4 4
1 2 3 4
1 4 1 4
2 3 2 3
3 2 3 3
4 1 2 4
Sample Output
9
7
6
7
很僵硬。。。一开始没有想到二进制Trie和值域线段树的转化。。。长知识了
Menci的blog写的挺好的
思路
首先考虑一下假设没有区间的限制怎么做?全局查找最优
因为如果没有加的操作我们很显然是可以在二进制Trie上贪心的
然是加上了加的操作怎么办?
就不要强行把加和异或联系起来了
假设我们从高到低已经选了\(tmp\),当前如果深度是\(dep\)
我们考虑这一位如果可能是0,那么一定在\([tmp,tmp+(1<<tmp)-1]\)范围内有数
如果考虑\(x_i\),就变成了在\([tmp-x_i,tmp+(1<<tmp)-1-x_i]\)范围内有数了
但是直接在Trie上做区间统计非常不方便怎么办?就考虑搬到权值线段树
实际上这两种数据结构的形态是完全相同的,只是实现方式不太一样
那么权值线段树是不是可以实现Trie的功能呢?答案是肯定的
所以就可以用权值线段树代替Trie了
这样如果需要加上区间的限制,就直接上个主席树就可以了。。。
或者你暴力可持久化Trie我没意见。。。。
//Author: dream_maker
#include<bits/stdc++.h>
using namespace std;
//----------------------------------------------
//typename
typedef long long ll;
//convenient for
#define fu(a, b, c) for (int a = b; a <= c; ++a)
#define fd(a, b, c) for (int a = b; a >= c; --a)
#define fv(a, b) for (int a = 0; a < (signed)b.size(); ++a)
//inf of different typename
const int INF_of_int = 1e9;
const ll INF_of_ll = 1e18;
//fast read and write
template <typename T>
void Read(T &x) {
bool w = 1;x = 0;
char c = getchar();
while (!isdigit(c) && c != '-') c = getchar();
if (c == '-') w = 0, c = getchar();
while (isdigit(c)) {
x = (x<<1) + (x<<3) + c -'0';
c = getchar();
}
if (!w) x = -x;
}
template <typename T>
void Write(T x) {
if (x < 0) {
putchar('-');
x = -x;
}
if (x > 9) Write(x / 10);
putchar(x % 10 + '0');
}
//----------------------------------------------
const int N = 2e5 + 10;
int rt[N], siz[N * 20], ls[N * 20], rs[N * 20], tot = 0;
void pushup(int t) {
siz[t] = siz[ls[t]] + siz[rs[t]];
}
void build(int &t, int l, int r) {
t = ++tot;
if (l == r) return ;
int mid = (l + r) >> 1;
build(ls[t], l, mid);
build(rs[t], mid + 1, r);
}
void insert(int &t, int last, int l, int r, int vl, int dep) {
t = ++tot;
siz[t] = siz[last] + 1;
ls[t] = ls[last];
rs[t] = rs[last];
if (l == r) return;
int mid = (l + r) >> 1;
if (vl & (1 << (dep - 1))) insert(rs[t], rs[last], mid + 1, r, vl, dep - 1);
else insert(ls[t], ls[last], l, mid, vl, dep - 1);
pushup(t);
}
bool query(int t, int last, int l, int r, int ql, int qr) {
if (ql > qr || l > r) return 0;
if (ql <= l && r <= qr) return siz[t] > siz[last];
int mid = (l + r) >> 1;
if (qr <= mid) return query(ls[t], ls[last], l, mid, ql, qr);
else if (ql > mid) return query(rs[t], rs[last], mid + 1, r, ql, qr);
else return query(ls[t], ls[last], l, mid, ql, mid) || query(rs[t], rs[last], mid + 1, r, mid + 1, qr);
}
int n, q, a[N], b[N], x[N], l[N], r[N];
void init() {
Read(n), Read(q);
fu(i, 1, n) Read(a[i]);
fu(i, 1, q) Read(b[i]), Read(x[i]), Read(l[i]), Read(r[i]);
}
int main() {
//freopen("1.in", "r", stdin);
init();
int maxv = 0;
fu(i, 1, n) maxv = max(maxv, a[i]);
fu(i, 1, q) maxv = max(maxv, max(b[i], x[i]));
int m = 1, dep = 0;
while (m < maxv + 1) m <<= 1, ++dep;
m--;
build(rt[0], 0, m);
fu(i, 1, n) insert(rt[i], rt[i - 1], 0, m, a[i], dep);
fu(i, 1, q) {
int ans = 0, tmp = 0;
fd(j, dep, 0) {
int now = 1 << j;
if (b[i] & now) {
if (query(rt[r[i]], rt[l[i] - 1], 0, m, max(0, tmp - x[i]), max(0, tmp - x[i] + now - 1))) {
ans |= now;
} else {
tmp |= now;
}
} else {
if (query(rt[r[i]], rt[l[i] - 1], 0, m, max(0, tmp - x[i] + now), max(0, tmp - x[i] + now * 2 - 1))) {
ans |= now;
tmp |= now;
}
}
}
Write(ans), putchar('\n');
}
return 0;
}
BZOJ4571: [Scoi2016]美味【主席树】【贪心】的更多相关文章
- BZOJ4571:[SCOI2016]美味(主席树,贪心)
Description 一家餐厅有 n 道菜,编号 1...n ,大家对第 i 道菜的评价值为 ai(1≤i≤n).有 m 位顾客,第 i 位顾客的期望值为 bi,而他的偏好值为 xi . 因此,第 ...
- BZOJ.4571.[SCOI2016]美味(主席树 贪心)
题目链接 要求 \(b\ xor\ (a_j+x)\) 最大,应让 \(a_j+x\) 的最高位尽可能与b相反.带个减法Trie树好像很难做?反正我不会. 从最高位开始,如果这位b是0/1,判断是否存 ...
- bzoj4571/luogu3293 美味 (主席树+贪心)
首先想到建出可持久化trie树然后在上面贪心,但是它加了一个数所以不能这么做 但依然可以贪心,仿照上面那个的过程,如果设y是在第i位上^b是1的数(前面的位数已经贪好了),我只要在[l,r]范围内能有 ...
- 【BZOJ4571】[Scoi2016]美味 主席树
[BZOJ4571][Scoi2016]美味 Description 一家餐厅有 n 道菜,编号 1...n ,大家对第 i 道菜的评价值为 ai(1≤i≤n).有 m 位顾客,第 i 位顾客的期望值 ...
- P3293 [SCOI2016]美味 主席树+按位贪心
给定长度为 \(n\) 序列 \(a[i]\) ,每次询问区间 \([l,r]\) ,并给定 \(b,x\) 中的一个数 \(p=a[i]\) ,使得最大化 \(b \bigoplus p^x\) 主 ...
- [SCOI2016]美味——主席树+按位贪心
原题戳这里 题解 让异或值最大显然要按位贪心,然后我们还发现加上一个\(x_i\)的效果就是所有\(a_i\)整体向右偏移了,我们对于\({a_i}\)开个主席树,支持查询一个区间中有多少个在\([L ...
- bzoj 4571: [Scoi2016]美味 (主席树)
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=4571 题面; 4571: [Scoi2016]美味 Time Limit: 30 Sec ...
- BZOJ4517[Scoi2016]美味——主席树
题目描述 一家餐厅有 n 道菜,编号 1...n ,大家对第 i 道菜的评价值为 ai(1≤i≤n).有 m 位顾客,第 i 位顾客的期 望值为 bi,而他的偏好值为 xi .因此,第 i 位顾客认为 ...
- bzoj 4571 [Scoi2016]美味——主席树
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4571 按位考虑,需要的就是一个区间:比如最高位就是(2^k -x). 对于不是最高位的位置该 ...
- [BZOJ4571][SCOI2016]美味(贪心+主席树)
经典问题,按位贪心,每次需要知道的是”在这一位之前的位都以确定的情况下,能否找到这一位是0/1的数”,这就是在询问[L,R]内某个值域区间是否有数,主席树即可. #include<cstdio& ...
随机推荐
- mysql主从复制,及扩展
一.MySQL简单复制相关概念: 1. mysql复制的意义:Mysql复制是使得mysql完成高性能应用的前提 2. mysql复制的机制: SLAVE端线程: IO thread: 向主服务请求二 ...
- org.apache.ibatis.exceptions.TooManyResultsException的异常排查过程
在查阅测试环境业务日志中的ERROR级别的日志时,发现了有一个Mybatis相关的异常错误org.apache.ibatis.exceptions.TooManyResultsException: E ...
- Python 日历模块calendar.monthrange 获取某一个月有多少天
import calendar monthRange = calendar.monthrange(2018, 10) (0, 31) 输出的是一个元组: 第一个元素,数字0是这个月的第一天是星期天(上 ...
- IBM究竟是一家怎样的公司
每次被问到这样的“简单”问题,我都很纠结: 这家公司,从创始至今已经积累了几十万种技术(2015年蝉联专利排行榜23年之久,仅2015年专利数7355项),开发了上万种产品(从银行的交易系统,到航空的 ...
- 前端工程化 - Yeoman
什么是Yeoman Yeoman是一个前端构建工具.它整合了yo(yeoman).gulp/grunt和npm/bower等工具,组成了一个完整的工具集合,为前端开发提供了一套完整的解决方案. Yeo ...
- js的数组与对象关系
有的时候总犯糊涂,不理解对象和数组的关系,转载一篇文章,深刻记忆一下 http://hi.baidu.com/samdan/item/05179313d1ee4b9e99ce3371 比如有一个数组a ...
- vue项目打包部署到nginx 服务器上
假如要实现的效果如下 http://ip/vue =>是进入首页访问的路径是 usr/local/nginx/html/vue http://ip/website =>是进 ...
- mybatis 环境搭建和基本说明
mybatis介绍就不多提了,直接步入正题. 先准备好eclipse和MySQL,然后先看一下目录结构 文件和类很少,所以mybatis的搭建是非常简单的,如搭建中遇到问题可以先参考文档最后一部分的综 ...
- 雷林鹏分享:Ruby CGI 编程
Ruby CGI 编程 Ruby 是一门通用的语言,不仅仅是一门应用于WEB开发的语言,但 Ruby 在WEB应用及WEB工具中的开发是最常见的. 使用Ruby您不仅可以编写自己的SMTP服务器,FT ...
- window下rabbitmq环境安装
最近项目想用个MQ来做业务分离,看了市面上众多产品,最后选了rabbitmq,理由很简单,对window的支持很到位(其实是公司的系列产品都是.net的). 安装方法什么的就不说了,直接到官网下载双击 ...