长度为N的正整数序列S,有Q次询问,每次询问一段区间内所有数的lcm(即最小公倍数)。由于答案可能很大,输出答案Mod 10^9 + 7。

 
例如:2 3 4 5,询问[1,3]区间的最小公倍数为2 3 4的最小公倍数 = 12。
Input
第1行:两个整数,N, Q,中间用空格分隔,N为数列长度,Q为询问数量。(2 <= N, Q <= 50000)
第2 - N + 1行:每行1个整数,对应数列中的元素(1 <= S[i] <= 50000)
第N + 2 - N + Q + 1行:每行2个数,l, r,表示询问下标i在[l, r]范围内的S[i]的最小公倍数。(1 <= l <= r <= N)
Output
输出共Q行,对应询问区间的最小公倍数Mod 10^9 + 7。
Input示例
3 3
123
234
345
1 2
2 3
1 3
Output示例
9594
26910
1103310 由于ai很小可以用各种方法乱搞,但这是一道论文题,原题的ai有1e9;
我们考虑这种有关lcm和gcd的题一种常用的处理方法就是分解质因数,这个题我们相当于是要求每个质因子的幂的最大值;
这个就很皮了,因为区间中不同质因子的数量是可能很多的,一个个枚举质因子肯定是假的;
我们可以考虑干这样一个骚操作,我们分解质因数的时候,我们就真的把他分解,比如说这个数有p^q,
那么我们就拆为p^1,p^2,p^3,...,p^q,这么多个数,然后每个数的权值为p,然后问题转化为区间中不同的数的乘积;
这样显然是对的,因为我们假设p这个质因子的最大次幂为q,那么会有p这个数会乘q次,因为有p^1,p^2,p^3...p^q每次都乘了p,满足lcm的定义;
于是我们发现这是一个经典的问题,对于每个数我们肯定是在他第一次出现在区间中的时候计算贡献,那么我们用类似HH的项链和采花的套路,用一个la[i],表示i位置上的数上一次出现的位置;
于是我们变为了询问[l,r]中la[i]<l的数的乘积,我们把询问按照右端点排序用树状数组维护前缀乘积即可,具体实现方法和采花类似;
论文链接里面还有各种做法,以及题目的分析过程
//MADE BY QT666
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<vector>
using namespace std;
typedef long long ll;
const int N=300050;
const int Mod=1e9+7;
int n,q,la[N],prime[N],tot,vis[N],a[N],b[N*20],v[N*20],tt,st[N],ed[N];
vector<int> p[N];
void pre(){
for(int i=2;i<=100000;i++){
if(!vis[i]) prime[++tot]=i;
for(int j=i;j<=100000;j+=i) vis[j]=1;
}
for(int i=1;i<=tot;i++){
for(int j=prime[i];j<=100000;j+=prime[i]) p[j].push_back(prime[i]);
}
}
struct data{
int l,r,id;
}Q[N];
int last[N];
bool cmp(const data &a,const data &b){
return a.r<b.r;
}
ll tr[N*20],ans[N];
int lowbit(int x){return x&-x;}
void update(int x,ll v){
if(x==0) return;
for(int i=x;i<=tt;i+=lowbit(i)) (tr[i]*=v)%=Mod;
}
ll query(int x){
ll ret=1;
for(int i=x;i;i-=lowbit(i)){
(ret*=1ll*tr[i])%=Mod;
}
return ret;
}
ll qpow(ll x,ll y){
ll ret=1;
while(y){
if(y&1) (ret*=x)%=Mod;
(x*=x)%=Mod;y>>=1;
}
return ret;
}
int main(){
scanf("%d%d",&n,&q);pre();
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
int x=a[i];st[i]=tt+1;
for(int j=0;j<p[a[i]].size();j++){
int y=p[a[i]][j],z=p[a[i]][j];
while(x%y==0){
b[++tt]=z;v[tt]=y;x/=y;z*=y;
}
}
ed[i]=tt;
}
for(int i=1;i<=q;i++){
scanf("%d%d",&Q[i].l,&Q[i].r);
Q[i].l=st[Q[i].l],Q[i].r=ed[Q[i].r],Q[i].id=i;
}
for(int i=1;i<=tt;i++) la[i]=last[b[i]],last[b[i]]=i;
sort(Q+1,Q+1+q,cmp);int l=1;
tr[0]=1;
for(int i=1;i<=tt;i++) tr[i]=1;
for(int i=1;i<=q;i++){
while(l<=Q[i].r){
update(la[l],qpow(v[l],Mod-2)),update(l,v[l]);l++;
}
ans[Q[i].id]=query(Q[i].r)*qpow(query(Q[i].l-1),Mod-2)%Mod;
}
for(int i=1;i<=q;i++) printf("%lld\n",ans[i]);
return 0;
}

51nod 1203 jzplcm的更多相关文章

  1. 2019.01.22 51nod 1203 JZPLCM(线段树+链表)

    传送门 一道很有意思的题. 题意简述:给一个数列,多次询问区间的lcmlcmlcm,答案对1e9+71e9+71e9+7取模. 思路:首先考虑到一个区间的lcmlcmlcm就是其中所有出现过的素数的最 ...

  2. 51 nod 1203 JZPLCM

    原题链接 长度为N的正整数序列S,有Q次询问,每次询问一段区间内所有数的lcm(即最小公倍数).由于答案可能很大,输出答案Mod 10^9 + 7.   例如:2 3 4 5,询问[1,3]区间的最小 ...

  3. 51Nod1203 2012集训队答辩 JZPLCM

    A1339. JZPLCM(顾昱洲) 时间限制:3.0s   内存限制:256.0MB   试题来源 2012中国国家集训队命题答辩 问题描述 给定一长度为n的正整数序列a,有q次询问,每次询问一段区 ...

  4. 【51Nod 1244】莫比乌斯函数之和

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1244 模板题... 杜教筛和基于质因子分解的筛法都写了一下模板. 杜教筛 ...

  5. 51Nod 1268 和为K的组合

    51Nod  1268  和为K的组合 1268 和为K的组合 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题 给出N个正整数组成的数组A,求能否从中选出若干个,使 ...

  6. 51Nod 1428 活动安排问题

    51Nod   1428  活动安排问题 Link: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1428 1428 活 ...

  7. 51Nod 1278 相离的圆

    51Nod 1278 相离的圆 Link: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1278 1278 相离的圆 基 ...

  8. 【51Nod 1501】【算法马拉松 19D】石头剪刀布威力加强版

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1501 dp求出环状不连续的前缀和,剩下东西都可以算出来,比较繁琐. 时间 ...

  9. 【51Nod 1622】【算法马拉松 19C】集合对

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1622 简单题..直接暴力快速幂 #include<cstdio&g ...

随机推荐

  1. 实时同步rsync+inotify

    实时同步rsync+inotify 原创博文http://www.cnblogs.com/elvi/p/7658071.html #linux同步 #实时同步rsync+inotify,双向同步ino ...

  2. ThreadLocal终极源码剖析

    目录一.ThreadLocal1.1 源码注释1.2 源码剖析      散列算法-魔数0x61c88647      set操作    get操作    remove操作1.3 功能测试1.4 应用 ...

  3. 算法(Python)

    算法就是为了解决某一个问题而采取的具体有效的操作步骤 算法的复杂度,表示代码的运行效率,用一个大写的O加括号来表示,比如O(1),O(n) 认为算法的复杂度是渐进的,即对于一个大小为n的输入,如果他的 ...

  4. Linux常用命令及部分详解

    1.总结部分 常用指令 ls      显示文件或目录 -l            列出文件详细信息l(list) -a            列出当前目录下所有文件及目录,包括隐藏的a(all) m ...

  5. 矩阵取数游戏洛谷p1005

    题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...

  6. 三种方法实现PCA算法(Python)

    主成分分析,即Principal Component Analysis(PCA),是多元统计中的重要内容,也广泛应用于机器学习和其它领域.它的主要作用是对高维数据进行降维.PCA把原先的n个特征用数目 ...

  7. 构建Nginx均衡LAMP高性能服务器

    LNAMP(Linux+Nginx+Apache+Mysql+PHP)架构受到很多IT企业的青睐,取代了原来认为很好的LNMP(Linux+Nginx+Mysql+PHP)架构,那我们说LNAMP到底 ...

  8. System.ServiceModel.CommunicationException: 已超过传入消息(65536)的最大消息大小配额。若要增加配额,请使用相应绑定元素上的 MaxReceivedMessageSize 属性。

  9. 阿里云轻量应用服务器Lamp部署php工程踩过的坑

    第一次写博客,也不知道写什么,但是想坚持写博客来提升自己,不喜勿喷. 切回正题,使用阿里云的轻量应用服务器Lamp其实非常方便,价格也很便宜,一键购买需要的环境都帮你搭配好了,剩下的就是自己修改一下数 ...

  10. Java开发小技巧(二):自定义Maven依赖

    前言 我们在项目开发中经常会将一些通用的类.方法等内容进行打包,打造成我们自己的开发工具包,作为各个项目的依赖来使用. 一般的做法是将项目导出成Jar包,然后在其它项目中将其导入,看起来很轻松,但是存 ...