洛谷P4587 [FJOI2016]神秘数(主席树)
题面
题解
考虑暴力,对于询问中的一段区间$[l,r]$,我们先将其中的数升序排序,假设当前可以表示出$[1,k]$目前处理$a_i$,假如$a_i>k+1$,则答案就是$k+1$,否则,调整右界到$k+a_i$。
考虑如何优化,还是扫到了$[1,k]$,假设$ans=k+1$,如果所有小于等于$ans$的数的和$sum$起来大于等于$ans$,则一定可以将$k$更新成$sum$。否则直接输出就好了。
以上这个过程很明显可以用主席树维护,统计一个区间内小于等于某个数的数的和。
接着来证明一下这个东西的复杂度。什么时候对于这种算法,复杂度最劣呢?就是,对于一个区间$[l,r]$,排完序后有:
$$
a_i=\sum_{j=l}^{i-1}a_j(l\leq i\leq r)
$$
比如:$1,1,2,4,8,16,...,2^k$,所以说,这个算法的复杂度是$log_2(\sum a_i)$,而$\sum a_i\leq10^9$,所以所以是对的
#include <cmath>
#include <cstdio>
#include <cstring>
#include <algorithm>
using std::min; using std::max;
using std::swap; using std::sort;
using std::unique; using std::lower_bound;
typedef long long ll;
template<typename T>
void read(T &x) {
int flag = 1; x = 0; char ch = getchar();
while(ch < '0' || ch > '9') { if(ch == '-') flag = -flag; ch = getchar(); }
while(ch >= '0' && ch <= '9') x = x * 10 + ch - '0', ch = getchar(); x *= flag;
}
const int N = 1e5 + 10, Inf = 1e9 + 7;
int n, q, a[N], rt[N], poi;
int val[N << 5], lson[N << 5], rson[N << 5];
ll sum[N << 5];
int insert(int o, int l, int r, int k) {
int o_ = ++poi;
lson[o_] = lson[o], rson[o_] = rson[o], sum[o_] = sum[o] + k;
if (l == r) return o_;
int mid = (l + r) >> 1;
if (k <= mid) lson[o_] = insert(lson[o_], l, mid, k);
else rson[o_] = insert(rson[o_], mid + 1, r, k);
return o_;
}
ll query (int x, int y, int l, int r, int k) {
if(l == r) return sum[y] - sum[x];
int mid = (l + r) >> 1;
if(k <= mid) return query(lson[x], lson[y], l, mid, k);
else return sum[lson[y]] - sum[lson[x]] +
query(rson[x], rson[y], mid + 1, r, k);
}
int main () {
read(n);
for(int i = 1; i <= n; ++i)
read(a[i]), rt[i] = insert(rt[i - 1], 1, Inf, a[i]);
read(q); int x, y;
while(q--) {
read(x), read(y);
ll MX = 1, ans = 0;
ans = query(rt[x - 1], rt[y], 1, Inf, int(MX));
while(ans >= MX && MX != Inf) {
MX = min(1ll * Inf, ans + 1);
ans = query(rt[x - 1], rt[y], 1, Inf, int(MX));
} printf("%lld\n", ans + 1);
}
return 0;
}
洛谷P4587 [FJOI2016]神秘数(主席树)的更多相关文章
- 洛谷 P4587 [FJOI2016]神秘数
大鸽子 llmmkk 正在补8.3号咕掉的题 时隔两个月,再看到这道题,我又是一脸懵,这种思维的培养太重要了 链接: P4587 题意: 给出 \(n\) 个点的序列,\(m\) 次询问区间神秘数. ...
- P4587 [FJOI2016]神秘数(主席树)
题意:给出1e5个数 查询l,r区间内第一个不能被表示的数 比如1,2,4可以用子集的和表示出[1,7] 所以第一个不能被表示的是8 题解:先考虑暴力的做法 把这个区间内的数字按从小到大排序后 从前往 ...
- LUOGU P4587 [FJOI2016]神秘数(主席树)
传送门 解题思路 如果区间内没有\(1\),那么答案就为\(1\),从这一点继续归纳.如果区间内有\(x\)个\(1\),设区间内\([2,x+1]\)的和为\(sum\),如果\(sum=0\),那 ...
- [[FJOI2016]神秘数][主席树]
明白之后 5min 就写好了-自闭- 这题的题意是问你 \([L,R]\) 区间的数字不能构成的数字的最小值- 首先考虑 如果 \([1,x]\) 可以被表示 那么加入一个 \(a_i\) 显然 \( ...
- 220722 T4 求和 /P4587 [FJOI2016]神秘数 (主席树)
好久没打主席树了,都忘了怎么用了...... 假设我们选了一些数能构成[0,x]范围内的所有值,下一个要加的数是k(k<=x+1),那么可以取到[0,x+k]内的所有取值,所以有一种做法: 对于 ...
- BZOJ 4408: [Fjoi 2016]神秘数 [主席树]
传送门 题意: 一个可重复数字集合S的神秘数定义为最小的不能被S的子集的和表示的正整数.例如S={1,1,1,4,13},8无法表示为集合S的子集的和,故集合S的神秘数为8.现给定n个正整数a[1]. ...
- 洛谷P2617 Dynamic Ranking(主席树,树套树,树状数组)
洛谷题目传送门 YCB巨佬对此题有详细的讲解.%YCB%请点这里 思路分析 不能套用静态主席树的方法了.因为的\(N\)个线段树相互纠缠,一旦改了一个点,整个主席树统统都要改一遍...... 话说我真 ...
- Luogu P4587 [FJOI2016]神秘数
一道好冷门的好题啊,算是对于一个小结论和数据结构的一点考验吧 首先看完题目我们发现要从这个神秘数的性质入手,我们观察or手玩可得: 如果有\(x\)个\(1\),那么\([1,x]\)都是可以表示出来 ...
- BZOJ4408&4299[Fjoi 2016]神秘数——主席树
题目描述 一个可重复数字集合S的神秘数定义为最小的不能被S的子集的和表示的正整数.例如S={1,1,1,4,13},1 = 1 2 = 1+1 3 = 1+1+1 4 = 4 5 = 4+1 6 = ...
随机推荐
- UVA 808 Bee Breeding (坐标法)
https://vjudge.net/problem/UVA-808 #include<cmath> #include<cstdio> #include<algorith ...
- JAVA获取Classpath根路径的方法
方法一: String path = Test.class.getResource("/").toString(); System.out.println("path = ...
- 【BZOJ4818】【SDOI2017】序列计数 [矩阵乘法][DP]
序列计数 Time Limit: 30 Sec Memory Limit: 128 MB[Submit][Status][Discuss] Description Alice想要得到一个长度为n的序 ...
- 15、简述MySQL的执行计划?
具体的Mysql的执行计划,请参考下面的链接: MySQL_执行计划详细说明
- 记一次Node项目的优化
这两天针对一个Node项目进行了一波代码层面的优化,从响应时间上看,是一次很显著的提升.一个纯粹给客户端提供接口的服务,没有涉及到页面渲染相关. 背景 首先这个项目是一个几年前的项目了,期间一直在新增 ...
- js_数组去重效率对比
学习javascript已经快两年了,也不知道到了什么程度了. 说说我对javascript的理解,在电脑的世界里,只有数据. 数组,对象,字符串.对这些数据进行操作就可以完成很多业务逻辑,和页面的交 ...
- Angular2.0 基础: Form
对于Angular2.0 的Form表单中的隐藏和验证,个人觉得还是挺有意思的. 1.通过ngModel 跟踪修改状态与验证. 在表单中使用 ngModel 可以获得更多的控制权,包括一些常用的验证. ...
- Linux目录结构与文件权限——(五)
1.目录结构
- Python脚本 - 查询磁盘的读写次数信息
测试系统为:Centos 6.7 Python版本为: 3.6.4 脚本功能:查看指定磁盘的读写及时间等相关信息 #!/usr/bin/env python3 from collections imp ...
- 机器学习开源项目精选TOP30
本文共图文结合,建议阅读5分钟. 本文为大家带来了30个广受好评的机器学习开源项目. 640?wx_fmt=jpeg&wxfrom=5&wx_lazy=1 最近,Mybridge发布了 ...