题目大意:长度n的序列, m个询问区间[L, R], 问区间内的所有子段的不同GCD值有多少种. 子段就是表示是要连续的a[]

思路:固定右端点,预处理出所有的gcd,每次都和i-1的gcd比较,然后不断放入gcd即可。

然后就是树状数组的更新,枚举右端点即可。然后我们知道,大区间不如小区间来的实惠,所以我们每次有重复gcd出现的时候,都要把大区间更换成小区间即可

下午脑子有点不清楚。。。2333看别人的博客蒙了好久

//看看会不会爆int!数组会不会少了一维!
//取物问题一定要小心先手胜利的条件
#include <bits/stdc++.h>
using namespace std;
#define LL long long
#define ALL(a) a.begin(), a.end()
#define pb push_back
#define mk make_pair
#define fi first
#define se second
/*
先总体说一下思路:求出区间的gcd,再对右进行排序,再枚举右端即可
*/
const int maxn = 1e5 + ;
int tree[maxn], a[maxn], pre[maxn * ], ans[maxn];
int n, q;
vector<pair<int, int> >qq[maxn], v[maxn]; int lowbit(int x) {return x & -x;}
int gcd(int a, int b){
return b == ? a : gcd(b, a % b);
} void update(int x, int val){
for (int i = x; i <= n; i += lowbit(i)){
tree[i] += val;
}
} int sum(int x){
int ans = ;
for (int i = x; i > ; i -= lowbit(i)) ans += tree[i];
return ans;
} void solve(){
memset(pre, , sizeof(pre));
memset(tree, , sizeof(tree)); for (int i = ; i <= n; i++){
int len = v[i].size();
for (int j = ; j < len; j++){
pair<int, int> g = v[i][j];
if (pre[g.first]) update(pre[g.first], -);
pre[g.first] = g.second;
update(g.second, );
}
len = qq[i].size();
for (int j = ; j < len; j++){
pair<int, int> p = qq[i][j];
ans[p.second] = sum(i) - sum(p.first - );
}
}
for (int i = ; i <= q; i++){
printf("%d\n", ans[i]);
}
} int main(){
while (scanf("%d%d", &n, &q) == ){
for (int i = ; i <= n; i++){
scanf("%d", a + i);
v[i].clear();
qq[i].clear();
}
for (int i = ; i <= n; i++){
int len = v[i - ].size();
int val = a[i], pos = i;
for (int j = ; j < len; j++){
pair<int, int> p = v[i - ][j];
int g = gcd(p.first, val);
if (g != val) {
v[i].pb(mk(val, pos));///要优先知道那一个区间里面的gcd
val = g;
pos = p.second;
}
}
v[i].pb(mk(val, pos));
}
/*
for (int i = 1; i <= n; i++){
int len = v[i].size();
for (int j = 0; j < len; j++){
printf("%d&%d ", v[i][j].first, v[i][j].second);
}
printf("\n");
}
*/
for (int i = ; i <= q; i++){
int l, r; scanf("%d%d", &l, &r);
qq[r].pb(mk(l, i));
}
solve();
}
return ;
}

区间gcd问题 HDU 5869 离线+树状数组的更多相关文章

  1. HDU 5869 (离线+树状数组)

    Problem Different GCD Subarray Query 题目大意 给定n个数的序列,有q个询问,每次询问一个区间中所有子区间所形成不同的gcd的数量. 解题分析 由于固定一个数为右端 ...

  2. 区间的关系的计数 HDU 4638 离线+树状数组

    题目大意:给你n个人,每个人都有一个id,有m个询问,每次询问一个区间[l,r],问该区间内部有多少的id是连续的(单独的也算是一个) 思路:做了那么多离线+树状数组的题目,感觉这种东西就是一个模板了 ...

  3. HDU 4417 离线+树状数组

    Super Mario Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  4. HDU - 4777 离线树状数组

    离线树状数组搞一搞. #include<bits/stdc++.h> #define LL long long #define fi first #define se second #de ...

  5. 利用id来进行树状数组,而不是离散化以后的val HDU 4417 离线+树状数组

    题目大意:给你一个长度为n的数组,问[L,R]之间<=val的个数 思路:就像标题说的那样就行了.树状数组不一定是离散化以后的区间,而可以是id //看看会不会爆int!数组会不会少了一维! / ...

  6. HDU 5249 离线树状数组求第k大+离散化

    KPI Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  7. HDU 5869 Different GCD Subarray Query rmq+离线+数状数组

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5869 Different GCD Subarray Query Time Limit: 6000/3 ...

  8. hdu 4605 Magic Ball Game (在线主席树/离线树状数组)

    版权声明:本文为博主原创文章,未经博主允许不得转载. hdu 4605 题意: 有一颗树,根节点为1,每一个节点要么有两个子节点,要么没有,每个节点都有一个权值wi .然后,有一个球,附带值x . 球 ...

  9. HDU 2852 KiKi's K-Number(离线+树状数组)

    题目链接 省赛训练赛上一题,貌似不难啊.当初,没做出.离线+树状数组+二分. #include <cstdio> #include <cstring> #include < ...

随机推荐

  1. 8636 跳格子(dfs+记忆化搜索)

    8636 跳格子 该题有题解 时间限制:2457MS  内存限制:1000K提交次数:139 通过次数:46 题型: 编程题   语言: G++;GCC Description 地上有一个n*m 的数 ...

  2. SuperMapPy 批量拼接 GeoTiff影像

    影像拼接工具使用说明 一.影像像素位深检查 1.采用开源库GDAL的gdalinfo.exe读取GeoTiff文件的信息,如类型.投影,范围等. 2.采用DOS脚本遍历所有GeoTiff文件,输出各个 ...

  3. android 进程(复习)

        前台进程 前台进程是用户当前正在使用的进程.只有一些前台进程可以在任何时候都存在.他们是最后一个被结束的,当内存低到根本连他们都不能运行的时候.一般来说, 在这种情况下,设备会进行内存调度,中 ...

  4. python实现邮件发送完整代码(带附件发送方式)

    实例一:利用SMTP与EMAIL实现邮件发送,带附件(完整代码) __author__ = 'Administrator'#coding=gb2312 from email.Header import ...

  5. 第十一节,编辑器软件PyCharm 5.0.3

    编辑器软件PyCharm 5.0.3 设置 主题方案 字体大小 行距 文件模板 文件编码 版本切换

  6. hdu_5792_World is Exploding(树状数组+逆序对)

    题目链接:hdu_5792_World is Exploding 题意: 给你一个数列,让你找有多少个(a,b,c,d)满足a≠b≠c≠d,1≤a<b≤n,1≤c<d≤n,Aa<Ab ...

  7. nefu 1116 字符串加密

    字符串加密 Problem : 1116 Time Limit : 1000ms Memory Limit : 65536K description 给你一段经过加密的字符串,我们称之为密文,现在请你 ...

  8. ECOS高可用集群

    此架构由8台PC .2台防火墙.2台24口三层交换机组成, 注意点: 1)Load Balance:Haprxoy+keepalived 实现高可用. 2)web:Nginx+php-fpm 3)DB ...

  9. mysql数据库参数innodb_buffer_pool_size和max_connections

    接到报故,查看mysql数据库以下参数 1.innodb_buffer_pool_size 2.max_connections 该参数定义了数据缓冲区buffer pool大小,类似于oracle的d ...

  10. GsonFormat 报错

    GsonFormat原来也有bug 我是用GsonFormat来生成java bean的,但是运行起来居然报 Caused by: java.lang.NumberFormatException: E ...