HDU 5726 GCD (RMQ + 二分)
题目链接: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 + 二分)的更多相关文章
- hdu 5726 GCD 倍增+ 二分
题目链接 给n个数, 定义一个运算f[l,r] = gcd(al, al+1,....ar). 然后给你m个询问, 每次询问给出l, r. 求出f[l, r]的值以及有多少对l', r' 使得f[l, ...
- HDU 5726 GCD 区间GCD=k的个数
GCD Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submis ...
- HDU 5726 GCD (2016多校、二分、ST表处理区间GCD、数学)
题目链接 题意 : 给出一个有 N 个数字的整数数列.给出 Q 个问询.每次问询给出一个区间.用 ( L.R ) 表示.要你统计这个整数数列所有的子区间中有多少个和 GCD( L ~ R ) 相等.输 ...
- hdu 3486 Interviewe (RMQ+二分)
Interviewe Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ...
- HDU 5726 GCD(RMQ+二分)
http://acm.split.hdu.edu.cn/showproblem.php?pid=5726 题意:给出一串数字,现在有多次询问,每次询问输出(l,r)范围内所有数的gcd值,并且输出有多 ...
- hdu 5726 GCD 暴力倍增rmq
GCD/center> 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5726 Description Give you a sequence ...
- HDU 5726 GCD(ST&RMQ)
题目链接 GCD 先ST倍增预处理,f[i][j]表示从i开始(包含第i个数)的连续2^j个数的最大公约数. 这样就可以在O(1)内询问得到a[l]到a[r]之间的所有数的最大公约数的值. 然后对于每 ...
- 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)个区间查询[ ...
- HDU 5726 GCD (2016 Multi-University Training Contest 1)
Time Limit: 5000MS Memory Limit: 65536KB 64bit IO Format: %I64d & %I64u Description Give y ...
随机推荐
- window注册表
打开注册表: 可以用快捷键 win + r ,然后输入 Regedit 回车,会打开注册表. 注册表添加一个键值对到 操作如下: 1.先创建一个 .reg 后缀的文件. 2.文件内容如下: Wind ...
- DirectSound播放PCM(可播放实时采集的音频数据)
前言 该篇整理的原始来源为http://blog.csdn.net/leixiaohua1020/article/details/40540147.非常感谢该博主的无私奉献,写了不少关于不同多媒体库的 ...
- 发布mvc3的项目时system.web.mvc 版本 为3.0.0.1高于服务器版本3.0.0.0 升级到3.0.0.1
下载地址在这里: http://www.microsoft.com/zh-cn/download/details.aspx?id=44533&WT.mc_id=rss_alldownloads ...
- web.xml元素介绍
每一个站的WEB-INF下都有一个web.xml的设定文件,它提供了对我们站台的配置设定.web.xml中定义元素有:◆站台的名称和说明◆针对环境参数(Context)做初始化工作◆Servlet的名 ...
- UVa 10837 (欧拉函数 搜索) A Research Problem
发现自己搜索真的很弱,也许做题太少了吧.代码大部分是参考别人的,=_=|| 题意: 给出一个phi(n),求最小的n 分析: 回顾一下欧拉函数的公式:,注意这里的Pi是互不相同的素数,所以后面搜索的时 ...
- POJ 3253 Fence Repair【二叉堆】
题意:给出n根木板,需要把它们连接起来,每一次连接的花费是他们的长度之和,问最少需要多少钱. 和上一题果子合并一样,只不过这一题用long long 学习的手写二叉堆的代码,再好好理解= = #inc ...
- kindeditor编辑器图片水印
//upload_pic.ashx源码 <%@ webhandler Language="C#" class="edit_html_upload_pic" ...
- IIS Web负载均衡的几种方式
Web负载均衡的几种实现方式 摘要:负载均衡(Load Balance)是集群技术(Cluster)的一种应用.负载均衡可以将工作任务分摊到多个处理单元,从而提高并发处理能力.目前最常见的负载均衡应用 ...
- 基于AJAX的长轮询(long-polling)方式实现简单的聊天室程序
原理: 可以看:http://yiminghe.javaeye.com/blog/294781 AJAX 的出现使得 JavaScript 可以调用 XMLHttpRequest 对象发出 HTTP ...
- Android PRODUCT_COPY_FILES 自动拷贝文件
/********************************************************************** * Android PRODUCT_COPY_FILES ...