先发掘性质:

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+\frac{n}{S}\log S)$。

当$S=\sqrt{n}$时复杂度最优,为$O(Q\sqrt{n}\log n)$。

 #include<cstdio>
#include<algorithm>
#define rep(i,l,r) for (int i=(l); i<=(r); i++)
typedef long long ll;
using namespace std; const int N=,K=;
char op[];
int n,B,tot,Q,ans,L[K],R[K];
ll x,k,a[N],G[K],X[K];
struct P{ ll x; int id; }p[N];
bool operator <(const P &a,const P &b){ return (a.x==b.x) ? a.id<b.id : a.x<b.x; } ll gcd(ll a,ll b){ return b ? gcd(b,a%b) : a; } void build(int x){
G[x]=X[x]=a[L[x]]; p[L[x]]=(P){X[x],L[x]};
rep(j,L[x]+,R[x]) G[x]=gcd(G[x],a[j]),X[x]^=a[j],p[j]=(P){X[x],j};
sort(p+L[x],p+R[x]+);
} int find(int l,int r,ll k){
while (l<r){
int mid=(l+r)>>;
if (p[mid].x<k) l=mid+; else r=mid;
}
return r;
} int main(){
freopen("bzoj4028.in","r",stdin);
freopen("bzoj4028.out","w",stdout);
scanf("%d",&n); B=; tot=(n-)/B+;
rep(i,,n) scanf("%lld",&a[i]);
rep(i,,tot) L[i]=(i-)*B+,R[i]=min(n,i*B),build(i);
for (scanf("%d",&Q); Q--; ){
scanf("%s",op);
if (op[]=='M') scanf("%lld%lld",&x,&k),x++,a[x]=k,build((x-)/B+);
else{
scanf("%lld",&x); ll g=a[],t=; bool w=;
rep(i,,tot){
if (gcd(g,G[i])==g){
if (x%g==){
ll k=x/g^t; int ans=find(L[i],R[i],k);
if (p[ans].x==(x/g^t)){ printf("%d\n",p[ans].id-); w=; break; }
}
g=gcd(g,G[i]); t^=X[i];
}else
rep(j,L[i],R[i]){
g=gcd(g,a[j]); t^=a[j];
if (g*t==x){ printf("%d\n",j-); w=; break; }
}
if (w) break;
}
if (!w) puts("no");
}
}
return ;
}

[BZOJ4028][HEOI2015]公约数数列(分块)的更多相关文章

  1. 【BZOJ4028】[HEOI2015]公约数数列 分块

    [BZOJ4028][HEOI2015]公约数数列 Description 设计一个数据结构. 给定一个正整数数列 a_0, a_1, ..., a_{n - 1},你需要支持以下两种操作: 1. M ...

  2. BZOJ 4028: [HEOI2015]公约数数列 分块

    4028: [HEOI2015]公约数数列 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4028 Description 设计一个数据结 ...

  3. BZOJ4028 HEOI2015公约数数列(分块)

    前缀gcd的变化次数是log的,考虑对每一种gcd查询,问题变为查询一段区间是否存在异或前缀和=x/gcd. 无修改的话显然可以可持久化trie,但这玩意实在没法支持修改.于是考虑分块. 对于每一块将 ...

  4. bzoj4028: [HEOI2015]公约数数列

    Description 设计一个数据结构. 给定一个正整数数列 a_0, a_1, ..., a_{n - 1},你需要支持以下两种操作: 1. MODIFY id x: 将 a_{id} 修改为 x ...

  5. [BZOJ4028][HAOI2015]公约数数列[分块+分析暴力]

    题意 题目链接 分析 首先明确 \(xor\) 运算和 \(\rm gcd\) 没有联系! 注意到一个数字取 \(\rm gcd\) 且保证每次取 \(\rm gcd\) 值都会变小的话,最多取 \( ...

  6. 【BZOJ4028】[HEOI2015]公约数数列(分块)

    [BZOJ4028][HEOI2015]公约数数列(分块) 题面 BZOJ 洛谷 题解 看一道题目就不会做系列 首先\(gcd\)最多只会有\(log\)种取值,所以我们可以暴力枚举出所有可能的\(g ...

  7. BZOJ 4028: [HEOI2015]公约数数列 【分块 + 前缀GCD】

    任意门:https://www.lydsy.com/JudgeOnline/problem.php?id=4028 4028: [HEOI2015]公约数数列 Time Limit: 10 Sec   ...

  8. 洛谷 P4108 / loj 2119 [HEOI2015] 公约数数列 题解【分块】

    看样子分块题应该做的还不够. 题目描述 设计一个数据结构. 给定一个正整数数列 \(a_0, a_1, \ldots , a_{n-1}\),你需要支持以下两种操作: MODIFY id x: 将 \ ...

  9. luogu P4108 [HEOI2015]公约数数列——solution

    -by luogu 不会啊.... 然后%了一发题解, 关键是 考虑序列{$a_n$}的前缀gcd序列, 它是单调不升的,且最多只会改变$log_2N$次,因为每变一次至少除2 于是,当我们询问x时: ...

随机推荐

  1. win10环境变量

    jdk8 JAVA_HOME D:\devsoft\jdk\jdk1.8 CLASSPATH .;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar pa ...

  2. Java简单爬虫(一)

    简单的说,爬虫的意思就是根据url访问请求,然后对返回的数据进行提取,获取对自己有用的信息.然后我们可以将这些有用的信息保存到数据库或者保存到文件中.如果我们手工一个一个访问提取非常慢,所以我们需要编 ...

  3. S3C6410 SPI全双工读写流程分析(原创)【转】

    转自:http://blog.csdn.net/hustyangju/article/details/21165721 原创博文,知识共享!转载请注明出处:http://blog.csdn.net/h ...

  4. openjudge-NOI 2.6-1759 最长上升子序列

    题目链接:http://noi.openjudge.cn/ch0206/1759/ 题解: 奇怪……之前博客里的o(nlogn)标程在codevs和tyvj上都能AC,偏偏它这里不行 #include ...

  5. SpringBoot微服务

    在企业级软件的架构模型上,我们主要讨论下SOA与微服务架构. SOA的全称是Service-Oriented Architecture,可译为“面向服务的架构”,它是一个组件模型,将应用程序的不同功能 ...

  6. hdu 5914(斐波拉契数列)

    Triangle Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Su ...

  7. Python 2 到 Python 3 的变化

    1: commands 被 subprocess 所取代:举例 Python2中使用getoutput: >>> import commands >>> print ...

  8. GLASNICI 解题报告

    GLASNICI 解题报告 题目描述 有N个人在一直线上,第i个人的位置为Di,满足Di≤Di+1.最初只有第1个人(在最左边)知道消息. 在任意时刻,每个人可以以每秒1单位的速度向左或向右移动,或者 ...

  9. EF – 5.DbSet与DbContext,数据更新奥秘

    5.6.4 <DbSet与DbContext> 介绍DbSet与DbContext中的核心属性及重要方法. 5.6.5 <数据更新的奥秘>  这一讲极为重要,因为它揭示出了En ...

  10. ***PHP5.6.x SSL3_GET_SERVER_CERTIFICATE:certificate verify failed 解决方案

    centos: 在php.ini中增加一行 1 openssl.cafile=/etc/pki/tls/certs/ca-bundle.crt 重启服务器使修改生效