题解

做了一下SCOI2015,于是决定搬运SCOI2016= v =

如果没有加法,我们可以向左向右节点查找

每个总权值是2^18 - 1,然后左右分,那么每次是一个完整的节点

如果有了加法,那么我们如果希望有数满足某一位是1或者0,是一段取值的区间,我们要保证这个区间的左右端点减少x后这个区间里还有值

我们可以通过一次\(\log n\)的操作完成这个东西

那么我们二分的话,复杂度也是\(\log n\)的

所以总复杂度就是\(O(m \log^2 n)\)的

代码

#include <bits/stdc++.h>
//#define ivorysi
#define MAXN 200005
typedef long long int64;
typedef unsigned int u32;
using namespace std;
const int MOD = 1000000007;
int n,m;
int a[MAXN];
struct node {
int lc,rc;
int size;
}tr[MAXN * 20];
int rt[MAXN],nodecnt;
int MAXVAL = 100000;
void add(const int &x,int &y,int l,int r,int pos) {
y = ++nodecnt;
tr[y] = tr[x];
tr[y].size++;
if(l == r)return;
int mid = (l + r) >> 1;
if(pos <= mid) add(tr[x].lc,tr[y].lc,l,mid,pos);
else add(tr[x].rc,tr[y].rc,mid + 1,r,pos);
}
int query(const int &u,int l,int r,int ql,int qr) {
if(l == ql && r == qr) return tr[u].size;
int mid = (l + r) >> 1;
if(qr <= mid) return query(tr[u].lc,l,mid,ql,qr);
else if(ql > mid) return query(tr[u].rc,mid + 1,r,ql,qr);
else {
return query(tr[u].lc,l,mid,ql,mid) + query(tr[u].rc,mid + 1,r,mid + 1,qr);
}
}
void Init() {
scanf("%d%d",&n,&m);
for(int i = 1 ; i <= n ; ++i) {
scanf("%d",&a[i]);
add(rt[i - 1],rt[i],0,MAXVAL,a[i]);
}
}
int getsize(int L,int R,int ql,int qr) {
if(ql < 0) ql = 0; qr = min(qr,MAXVAL);
if(qr < ql) return 0 ;
return query(rt[R],0,MAXVAL,ql,qr) - query(rt[L - 1],0,MAXVAL,ql,qr);
}
int Binary(int b,int x,int Lrt,int Rrt) {
int L = 0,R = (1 << 18) - 1;
int NUM = 0;
for(int i = 17 ; i >= 0 ; --i) {
if(b >> i & 1) {
int T = NUM + (1 << i) - 1;
if(getsize(Lrt,Rrt,L - x,T - x) > 0) {
R = T;
}
else {
L = T + 1;
NUM += (1 << i);
}
}
else {
int T = NUM + (1 << i);
if(getsize(Lrt,Rrt,T - x,R - x) > 0) {
NUM += (1 << i);
L = T;
}
else R = T - 1;
}
}
return b ^ NUM;
}
void Solve() {
Init();
int b,x,l,r;
while(m--) {
scanf("%d%d%d%d",&b,&x,&l,&r);
printf("%d\n",Binary(b,x,l,r));
}
} int main() {
#ifdef ivorysi
freopen("food1.in","r",stdin);
#endif
Solve();
}

【LOJ】#2016. 「SCOI2016」美味的更多相关文章

  1. loj#2016. 「SCOI2016」美味

    题目链接 loj#2016. 「SCOI2016」美味 题解 对于不带x的怎么做....可持久化trie树 对于带x,和trie树一样贪心 对于答案的二进制位,从高往低位贪心, 二进制可以表示所有的数 ...

  2. AC日记——「SCOI2016」美味 LiBreOJ 2016

    #2016. 「SCOI2016」美味 思路: 主席树: 代码: #include <bits/stdc++.h> using namespace std; #define maxa 26 ...

  3. 「SCOI2016」美味 解题报告

    「SCOI2016」美味 状态极差无比,一个锤子题目而已 考虑每次对\(b\)和\(d\)求\(c=d \ xor \ (a+b)\)的最大值,因为异或每一位是独立的,所以我们可以尝试按位贪心. 如果 ...

  4. loj#2013. 「SCOI2016」幸运数字 点分治/线性基

    题目链接 loj#2013. 「SCOI2016」幸运数字 题解 和树上路径有管...点分治吧 把询问挂到点上 求出重心后,求出重心到每个点路径上的数的线性基 对于重心为lca的合并寻味,否则标记下传 ...

  5. loj#2015. 「SCOI2016」妖怪 凸函数/三分

    题目链接 loj#2015. 「SCOI2016」妖怪 题解 对于每一项展开 的到\(atk+\frac{dnf}{b}a + dnf + \frac{atk}{a} b\) 令$T = \frac{ ...

  6. loj#2012. 「SCOI2016」背单词

    题目链接 loj#2012. 「SCOI2016」背单词 题解 题面描述有点不清楚. 考虑贪心 type1的花费一定不会是优的,不考虑, 所以先把后缀填进去,对于反串建trie树, 先填父亲再填儿子, ...

  7. 「SCOI2016」美味

    「SCOI2016」美味 题目描述 一家餐厅有 \(n\) 道菜,编号 \(1 \ldots n\) ,大家对第 \(i\) 道菜的评价值为 \(a_i \:( 1 \leq i \leq n )\) ...

  8. loj #2013. 「SCOI2016」幸运数字

    #2013. 「SCOI2016」幸运数字 题目描述 A 国共有 n nn 座城市,这些城市由 n−1 n - 1n−1 条道路相连,使得任意两座城市可以互达,且路径唯一.每座城市都有一个幸运数字,以 ...

  9. LOJ #2013「SCOI2016」幸运数字

    时限为什么这么大啊 明摆着放多$ log$的做法过啊$QAQ$ LOJ #2013 题意 有$ Q$次询问,每次询问树上一条链,点有点权,你需要选择一些链上的点使得异或和尽量大 点数$ \leq 2* ...

随机推荐

  1. poj 1696 (计算几何基础)

    poj 1696 Space Ant 链接:http://poj.org/problem?id=1696 题意:在坐标轴上,给定n个点的 id 以及点的坐标(xi, yi),让你以最底端点开始,从右依 ...

  2. discuz uc_server 配置登录

    新运行uc_server环境,先配置好ucenter链接-----这部很重要,我从新环境中安装下载的discuz代码,这部没配置,密码又不知道,怎么更改调试,都不起作用,在框架中,跳转到了原来线上的u ...

  3. Nginx--try_files

    Nginx的配置语法灵活,可控制度非常高.在0.7以后的版本中加入了一个try_files指令,配合命名location,可以部分替代原本常用的rewrite配置方式,提高解析效率.   作用域:se ...

  4. LeakCanary原理分析

    参考文档 http://blog.csdn.net/wyfei021/article/details/46506521http://vjson.com/wordpress/leakcanary%e6% ...

  5. HDU6127 简单几何 暴力二分

    LINK 题意:给出n个点,每个点有个权值,可以和任意另外一点构成线段,值为权值积.现问过原点的直线中交所有线段的权值和的最大值,注意直线必不经过点. 思路:直线可以将点集分为两侧,此时的权值为两侧点 ...

  6. User-Agent大全

    一.基础知识篇: Http Header之User-Agent User Agent中文名为用户代理,是Http协议中的一部分,属于头域的组成部分,User Agent也简称UA.它是一个特殊字符串头 ...

  7. (三)配置Hadoop1.2.1+eclipse(Juno版)开发环境,并运行WordCount程序

    配置Hadoop1.2.1+eclipse(Juno版)开发环境,并运行WordCount程序 一.   需求部分 在ubuntu上用Eclipse IDE进行hadoop相关的开发,需要在Eclip ...

  8. [csp-201809-3]元素选择器-编译原理

    声明:同样是参考照抄hyh学长的代码!(有问题我马上删这篇emm 题目链接:http://118.190.20.162/view.page?gpid=T77 题面: 这棵树的样子(同样是来自学长的图) ...

  9. [转]C语言指针详解(经典,非常详细)

    博文地址:https://blog.csdn.net/constantin_/article/details/79575638 写得很好啊! 这里写一下笔记好了 int p; //这是一个普通的整型变 ...

  10. Calendar 日期类介绍

    Calendar c = Calendar.getInstance();//创建实例 默认是当前时刻 c.get(Calendar.YEAR); c.get(Calendar.MONTH); c.ge ...