题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5726

给你n个数,q个询问,每个询问问你有多少对l r的gcd(a[l] , ... , a[r]) 等于的gcd(a[l'] ,..., a[r'])。

先用RMQ预处理gcd,dp[i][j] 表示从i开始2^j个数的gcd。

然后用map存取某个gcd所对应的l r的数量。

我们可以在询问前进行预处理,先枚举i,以i为左端点的gcd(a[i],..., a[r])的种类数不会超过log2(n),gcd呈单调不增性。(因为gcd值每次变化,至少除以2)

所以所有的gcd的种类个数最多就nlog2(n)。

明白之后,我们可以枚举i为左端点固定,然后二分一下右端点,计算每种gcd的数量。

大概理解之后就可以敲了,然后就是细节问题。

 #include <algorithm>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <string>
#include <cstdio>
#include <vector>
#include <ctime>
#include <cmath>
#include <queue>
#include <set>
#include <map>
using namespace std;
#define Fill(x, y) memset((x), (y), sizeof(x))
#define Rep(i, x, y) for(int i = x; i <= y; ++i)
#define Dow(i, x, y) for(int i = x; i >= y; --i)
typedef long long LL;
typedef pair <int, int> P;
typedef pair <LL, LL> PLL;
const LL mod = 1e9 + ;
const LL inf = 1e18;
const int N = 1e5 + ;
int GCD(int a, int b) {
return b ? GCD(b, a % b) : a;
} int dp[N][];
map <int , LL> mp; void ST(int n) {
for(int k = ; k < ; ++k) {
for(int i = ; i + ( << k) - <= n ; ++i) {
dp[i][k] = GCD(dp[i][k - ] , dp[i + ( << (k - ))][k - ]);
}
}
} int rmq(int l , int r) {
int k = log2(r - l + );
return GCD(dp[l][k] , dp[r - ( << k) + ][k]);
} int main()
{
int t , n , q , u , v;
scanf("%d" , &t);
for(int ca = ; ca <= t ; ++ca) {
scanf("%d" , &n);
for(int i = ; i <= n ; ++i)
scanf("%d" , &dp[i][]);
ST(n);
mp.clear();
for(int i = ; i <= n ; ++i) {
int l , r , temp = i , gcd = dp[i][] , s = i;
do {
l = temp , r = n;
s = l , gcd = rmq(i , s);
while(l <= r) {
int mid = (l + r) / ;
temp = mid;
if(rmq(i , mid) < gcd) {
r = mid - ;
temp = mid - ;
}
else {
l = mid + ;
}
}
mp[gcd] += (LL)(temp - s + );
temp++;
}while(temp <= n);
}
printf("Case #%d:\n" , ca);
scanf("%d" , &q);
while(q--) {
scanf("%d %d" , &u , &v);
int gcd = rmq(u , v);
printf("%d %lld\n" , gcd , mp[gcd]);
}
}
return ;
}

HDU 5726 GCD (RMQ + 二分)的更多相关文章

  1. hdu 5726 GCD 倍增+ 二分

    题目链接 给n个数, 定义一个运算f[l,r] = gcd(al, al+1,....ar). 然后给你m个询问, 每次询问给出l, r. 求出f[l, r]的值以及有多少对l', r' 使得f[l, ...

  2. HDU 5726 GCD 区间GCD=k的个数

    GCD Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submis ...

  3. HDU 5726 GCD (2016多校、二分、ST表处理区间GCD、数学)

    题目链接 题意 : 给出一个有 N 个数字的整数数列.给出 Q 个问询.每次问询给出一个区间.用 ( L.R ) 表示.要你统计这个整数数列所有的子区间中有多少个和 GCD( L ~ R ) 相等.输 ...

  4. hdu 3486 Interviewe (RMQ+二分)

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

  5. HDU 5726 GCD(RMQ+二分)

    http://acm.split.hdu.edu.cn/showproblem.php?pid=5726 题意:给出一串数字,现在有多次询问,每次询问输出(l,r)范围内所有数的gcd值,并且输出有多 ...

  6. hdu 5726 GCD 暴力倍增rmq

    GCD/center> 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5726 Description Give you a sequence ...

  7. HDU 5726 GCD(ST&RMQ)

    题目链接 GCD 先ST倍增预处理,f[i][j]表示从i开始(包含第i个数)的连续2^j个数的最大公约数. 这样就可以在O(1)内询问得到a[l]到a[r]之间的所有数的最大公约数的值. 然后对于每 ...

  8. 2016 Multi-University Training Contest 1 GCD RMQ+二分(预处理)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=5726 题意:有N(N <= 100,000),之后有Q(Q <= 100,000)个区间查询[ ...

  9. HDU 5726 GCD (2016 Multi-University Training Contest 1)

      Time Limit: 5000MS   Memory Limit: 65536KB   64bit IO Format: %I64d & %I64u Description Give y ...

随机推荐

  1. Linux 下查看文件字符编码和转换编码

    Linux 下查看文件字符编码和转换编码 如果你需要在Linux中操作windows下的文件,那么你可能会经常遇到文件编码转换的问题.Windows中默认的文件格式是GBK(gb2312),而Linu ...

  2. 深入学习android之AlarmManager

    对应AlarmManage有一个AlarmManagerServie服务程 序,该服务程序才是正真提供闹铃服务的,它主要维护应用程序注册下来的各类闹铃并适时的设置即将触发的闹铃给闹铃设备(在系统中,l ...

  3. AWS 之 S3篇<.NET(c#)批量上传文件>

    第一次知道AWS然后网上就研究了一番,如果也是第一次知道这个的话,或者对这个只知道是干什么,并没有写个相关的程序的话,可以看看这个网址http://docs.aws.amazon.com/zh_cn/ ...

  4. bzoj4011

    好题,首先有一个结论,有向无环图的树形图数目=根节点意外入度之积 现在相当于在原图上加一条边问树形图的数目 考虑多出来不合法的方案,一定是成环且包含新加入的边 对于一条路贡献就是∏d[i] [i∉pa ...

  5. LA 5009 (三分法求极值) Error Curves

    给出的曲线要么是开口向上的抛物线要么是直线,但所定义的F(x)的图形一定是下凸的. 注意一点就是求得是极小值,而不是横坐标,样例也很容易误导人. #include <cstdio> #in ...

  6. Asp.Net MVC Views页面不包含“GetEnumerator”的公共定义

    “/”应用程序中的服务器错误. 编译错误 说明: 在编译向该请求提供服务所需资源的过程中出现错误.请检查下列特定错误详细信息并适当地修改源代码. 编译器错误消息: CS1579: “Web.Model ...

  7. 转:MVC3系列:~Html.BeginForm与Ajax.BeginForm

    Html.BeginForm与Ajax.BeginForm都是MVC架构中的表单元素,它们从字面上可以看到区别,即Html.BeginForm是普通的表单提交,而Ajax.BeginForm是支持异步 ...

  8. AI 行为树

    by AKara 2010-12-09 @ http://blog.csdn.net/akara @ akarachen(at)gmail.com @weibo.com/akaras 谈到游戏AI,很 ...

  9. Android service binder aidl 关系

    /********************************************************************************** * Android servic ...

  10. 使用java解析和制作二维码

    项目结构 文件源码 QR.zip 第一步:导入zxing的两个架包 core.jar和javase.jar 第二步:使用工具类 MatrixToImageWriter.java package uti ...