bzoj4028】的更多相关文章

[BZOJ4028][HEOI2015]公约数数列(分块) 题面 BZOJ 洛谷 题解 看一道题目就不会做系列 首先\(gcd\)最多只会有\(log\)种取值,所以我们可以暴力枚举出所有可能的\(gcd\). 那么我们现在按照步骤要解决两个问题.第一个是怎么动态维护\(gcd\)的取值,第二个是怎么动态维护异或和. 我们考虑分块. 只维护块内的前缀\(gcd\)和前缀异或和,这样子每次修改只需要暴力重构块. 每次询问的时候如果块内的\(gcd\)不变,那么二分答案,找找有没有满足条件的异或和.…
先发掘性质: 1.xor和gcd均满足交换律与结合率. 2.前缀gcd最多只有O(log)个. 但并没有什么数据结构能同时利用这两个性质,结合Q=10000,考虑分块. 对每块记录这几个信息: 1.块内所有数的gcd与异或和. 2.将块内所有前缀异或和放入一个数组排序. 查询时从前往后遍历每个块: 1.若当前块不使gcd改变,二分查找是否存在答案. 2.若改变,暴力查找答案. 复杂度(设块大小为S,值域为M): 1.修改复杂度$O(S\log S)$ 2.查询复杂度$O(S\log M+\fra…
前缀gcd的变化次数是log的,考虑对每一种gcd查询,问题变为查询一段区间是否存在异或前缀和=x/gcd. 无修改的话显然可以可持久化trie,但这玩意实在没法支持修改.于是考虑分块. 对于每一块将其中所有块内异或前缀和排序.查询时先看这块与上一块相比gcd有没有变化,如果有对其中每个位置暴力查询,否则在排序后的数组中二分.修改时暴力改每一块的前缀gcd及异或和,被修改的块暴力重构排序数组即可. #include<iostream> #include<cstdio> #inclu…
[BZOJ4028][HEOI2015]公约数数列 Description 设计一个数据结构. 给定一个正整数数列 a_0, a_1, ..., a_{n - 1},你需要支持以下两种操作: 1. MODIFY id x: 将 a_{id} 修改为 x. 2. QUERY x: 求最小的整数 p (0 <= p < n),使得 gcd(a_0, a_1, ..., a_p) * XOR(a_0, a_1, ..., a_p) = x. 其中 XOR(a_0, a_1, ..., a_p) 代表…
一眼分块题…… 分块,维护每个块的总的gcd和xor和 先思考我们应该怎么查询,考虑到gcd是一个神奇的东西,因为它最多变化logX次 于是我们从前往后扫描每个块,如果一个块内总的gcd是当前扫描的前缀gcd的倍数 那么,也就意味着这个块里的每个位置所对应的前缀的gcd都等于当前gcd 因此,我们设当前xor和为nowxor,gcd为nowgcd,partxor为块内某个块前缀xor和 nowxor xor partxor*nowgcd=x 即 nowxor xor (x/nowgcd)=par…
Description 设计一个数据结构. 给定一个正整数数列 a_0, a_1, ..., a_{n - 1},你需要支持以下两种操作: 1. MODIFY id x: 将 a_{id} 修改为 x. 2. QUERY x: 求最小的整数 p (0 <= p < n),使得 gcd(a_0, a_1, ..., a_p) * XOR(a_0, a_1, ..., a_p) = x. 其中 XOR(a_0, a_1, ..., a_p) 代表 a_0, a_1, ..., a_p 的异或和,g…
题意 题目链接 分析 首先明确 \(xor\) 运算和 \(\rm gcd\) 没有联系! 注意到一个数字取 \(\rm gcd\) 且保证每次取 \(\rm gcd\) 值都会变小的话,最多取 \(\log\) 次. 比较显然,如果每次都变小的话至少都除以了因子 \(2\) ,变为原来的二分之一. 所以考虑一个暴力分块,记录每一块的 \(\rm gcd\) G[i].异或和X[i].前缀异或和. 如果 \({\rm gcd}(lastgcd,G[i])=lastgcd\) ,那么直接在该块记录…
(这篇我就不信有网站来扣) 这个暑假打算刷刷题啥的 但是写博客好累啊  堆一起算了 隔一段更新一下.  7月27号之前刷的的就不写了 , 写的累 代码不贴了,可以找我要啊.. 2017.8.27update : 开学了终于搞到了550  可还行 *数据结构 *可持久化线段树/主席树 *bzoj3932 [CQOI2015] 任务查询系统 : 比较裸的主席树,任务查分一下就好了  cqoi真良心 *bzoj4026 dC Loves Number Theory :  数论个头啊,对每个数分解质因数…