珂朵莉的约数

来源:牛客网:

题目描述

珂朵莉给你一个长为n的序列,有m次查询

每次查询给两个数l,r

设s为区间[l,r]内所有数的乘积

求s的约数个数mod 1000000007

输入描述:
第一行两个正整数n,m
第二行一个长为n的序列
之后m行每行两个数l和r
输出描述:
对于每个询问,输出一个整数表示答案
示例1
输入
复制

5 5
64 2 18 9 100
1 5
2 4
2 3
1 4
3 4

输出
复制

165
15
9
45
10

备注:
对于100%的数据,有n , m <= 100000 , a[i] <= 1000000

题解:

莫队+数论(约数个数)
很容易看出是莫队的题,个人认为难点在于求约数的个数,常规的求约束的个数肯定不行,有一个叫约束个数定理的东西
任何一个大于1的n都可以分解:
n=p1a1×p2a2×p3a3*…*pkak,p为素数
而n的约数的个数就是(a1+1)(a2+1)(a3+1)…(ak+1)
再看一下本题数据,对于不超过1000的素数我们可以直接维护每个素数的幂指数+1的前缀乘积(共168个),而超过1000的素因数最多也就一个。代码中ant用来记录1000之外的素因子,res用来记录1000之内的每个素数的幂指数+ 1 +1+1的前缀乘积
线性筛就是每一次被最小素因数给筛出来,所以用线性筛来计算因数和。因为题目要mod,所以我们还要线性预处理逆元,方便后面使用

nv[0] = inv[1] = 1; for(int i=2;i<=n+1;i++) inv[i]=1ll*(MOD-MOD/i)*inv[MOD%i]%MOD ; 

具体线性筛如何求因数和可以看其他博客讲解
具体代码如下

代码:

#include <bits/stdc++.h>using namespace std;
typedef long long ll;
const int N = 1e5 + 10;
const int MOD = 1e9+7;int prime[1007],tot;
bool vis[1007];
ll inv[N],ans[N],ant;
int Be[N],a[N],sum[N*10],pre[N][170]; // sum存 在区间内 > 1000 的素数的个数
void init()
{tot = 0;for(int i = 2;i <= 1000;i++){if(vis[i])  continue;prime[tot++] = i;for(int j = i + i; j <= 1000; j += i )vis[j] = 1;}
}struct Mo{int l,r,id;
}Q[N];
int cmp(Mo a,Mo b){ return Be[a.l] == Be[b.l] ? a.r < b.r : a.l < b.l;}void add(int pos)
{if(a[pos] == 1) return;ant = ant*inv[1+sum[a[pos]]]%MOD;sum[a[pos]]++;ant = ant*(1+sum[a[pos]])%MOD;
}
void del(int pos)
{if(a[pos] == 1) return;ant = ant*inv[1+sum[a[pos]]]%MOD;sum[a[pos]]--;ant = ant*(1+sum[a[pos]])%MOD;
}
int main()
{int n,m;init();scanf("%d%d",&n,&m);inv[0] = inv[1] = 1; for(int i=2;i<=n+1;i++) inv[i]=1ll*(MOD-MOD/i)*inv[MOD%i]%MOD ;  // 逆元筛int len = sqrt(n);for(int i = 1;i <= n;i++){scanf("%d",&a[i]);Be[i] = i/len;for(int j = 0;j < tot;j++){pre[i][j] = pre[i-1][j];while(a[i] % prime[j] == 0)//如果这个质数是因子 {pre[i][j]++;a[i] /= prime[j]; }}}for(int i = 1;i <= m;i++)   scanf("%d%d",&Q[i].l,&Q[i].r),Q[i].id = i;sort(Q+1,Q+m+1,cmp);memset(sum,0,sizeof(sum));ant = 1;int l = 1,r = 0;for(int i = 1;i <= m;i++){while(r < Q[i].r)   add(r+1),r++;while(r > Q[i].r)   del(r),r--;while(l < Q[i].l)   del(l),l++;while(l > Q[i].l)   add(l-1),l--;ll res = 1;for(int j=0;j<tot;j++)res=1ll*res*(pre[r][j]-pre[l-1][j]+1)%MOD;ans[Q[i].id] = 1ll*ant*res%MOD;}for(int i = 1;i <= m;i++)printf("%lld\n",ans[i]);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319188.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AtCoder Regular Contest 110 E.Shorten ABC——坑

计数渣渣不会啊 下学期学概率论与数理统计不知道会不会提升数数能力 E.Shorten ABC 当B数组确定后&#xff0c;不难发现就是所问问题即从B序列选出A序列的方案数。 等效于那么从mn中选出sn个小球&#xff0c;我们假设多选的n个小球是一个隔板&#xff0c;隔出数组A&#xff0…

【DP】Rotating Substrings(CF1363F)

正题 luogu CF1363F 题目大意 给你一个字符串&#xff0c;你以旋转其中一个字串&#xff08;将最后一给点移到前面&#xff0c;然后整体向后移一位&#xff09;&#xff0c;问最少要多少布可以到目标字符串 解题思路 设 fi,jf_{i,j}fi,j​ 为 sss 中的前 iii 个字符构成 ttt…

P3348-[ZJOI2016]大森林【LCT】

正题 题目链接:https://www.luogu.com.cn/problem/P3348 题目大意 有nnn棵树开始只有一个编号为111的节点且为标记点。mmm次操作要求支持 在l∼rl\sim rl∼r的树中的标记点下面加入一个新的编号的节点将l∼rl\sim rl∼r的树上的标记点改为xxx&#xff08;如果没有节点xxx就不…

SmartCode 常见问题

SmartCode 能干什么&#xff1f;SmartCode IDataSource -> IBuildTask -> IOutput > Build EverythingSmartCode的执行流是 数据源->构建任务->输出&#xff0c;也就是说应用场景非常广泛。从DB读取数据结构&#xff0c;最终生成整个解决方案代码生成器&#x…

[数论]线性筛——约数个数与约数和

参考博客 参考博客 参考博客 这个讲的挺好 预备知识点&#xff1a; 大于1的数n可以分解质因数&#xff1a; np1a1p2a2p3a3*…*pka n的约数的个数是(a11) * (a21) * (a31)…(ak1) 我们先用线性筛来筛出素数 bool mark[maxn]; int prim[maxn]; int cnt; void initial() {cnt0;f…

F. Paper Grading(Trie树+dfs序+二维数点)

F. Paper Grading 大佬题解 一般关于前缀的问题基本都是Trie树。 首先将所给字符串建立一棵Trie树&#xff0c;Trie能够解决一个字符串在一个字符串集合中出现的次数&#xff0c;而查询前缀次数只需要找到Trie树中所给字符末尾的位置&#xff0c;那么其子树中打标记的次数即前…

AT2164-[AGC006C]Rabbit Exercise【差分,倍增,数学期望】

正题 题目链接:https://www.luogu.com.cn/problem/AT2164 题目大意 nnn只兔子编号为1∼n1\sim n1∼n&#xff0c;第iii只在坐标轴xix_ixi​处。然后mmm次跳跃&#xff0c;每次给出aia_iai​&#xff0c;编号为aia_iai​的兔子会等概率的选取ai−1a_{i-1}ai−1​和ai1a_{i1}ai1…

k-substrings(CF961F)

正题 luogu CF961F 题目大意 给你一个字符串T&#xff0c;对于k1~n/2&#xff0c;找到最长的串s&#xff0c;满足s是T左右各删除k个字符构成的字串t的前缀后缀&#xff08;不能是整个字符串&#xff09; 解题思路 不难发现&#xff0c;k的答案左右各删一个字符必定能得到k1的…

全面支持开源,微软加速 Visual Studio 和 Azure DevOps 云升级

在 2018 微软技术暨生态大会&#xff08;Microsoft Tech Summit&#xff09;上&#xff0c;微软宣布围绕 Visual Studio 和 Visual Studio Code 开发平台提供一系列新功能与服务&#xff0c;并对 Azure DevOps 研发云进行整合升级&#xff0c;通过 Visual Studio 开发平台与微软…

求约数个数的和

今天一下午都在研究约数的各种性质。。。 求约数个数的和可以用线性筛的方式&#xff0c;线性求解的方式&#xff0c;这应该是最快的 [数论]线性筛——约数个数与约数和 除此之外还有代码更简便方法&#xff1a; 对应的例题 方法一&#xff1a; #include <iostream> …

I. Space Station(hash记忆化+dp)

《文章》陆游 文章本天成&#xff0c;妙手偶得之。 粹然无疵瑕&#xff0c;岂复须人为。 君看古彝器&#xff0c;巧拙两无施。 汉最近先秦&#xff0c;固已殊淳漓。 胡部何为者&#xff0c;豪竹杂哀丝。 后夔不复作&#xff0c;千载谁与期&#xff1f; I. Space Station 大佬…

HttpClient参观记:.net core 2.2 对HttpClient到底做了什么?

.net core 于 10月17日发布了 ASP.NET Core 2.2.0 -preview3&#xff0c;在这个版本中&#xff0c;我看到了一个很让我惊喜的新特性&#xff1a;HTTP Client Performance Improvements &#xff0c;而且在Linux上性能提升了60% !之前就一直苦于 HttpClient 的糟糕特性&#xff…

【线段树】Serious Business(CF1648D)

正题 luogu CF1648D 题目大意 有一个 3*n 的矩阵&#xff0c;1,3行没有行走限制&#xff0c;对于第2行&#xff0c;有m个区间&#xff0c;覆盖第 i 个区间有 kik_iki​ 的代价&#xff0c;只有覆盖的位置才能走&#xff0c;让你从 (1,1) 走到 (3,n)&#xff08;只能向下和向右…

P6378-[PA2010]Riddle【2-SAT】

正题 题目链接:https://www.luogu.com.cn/problem/P6378 题目大意 给出nnn个点mmm条边的一张无向图&#xff0c;图中有kkk种颜色的点。 要求每种颜色选择一个点作为关键点&#xff0c;满足每条边两边至少有一个关键点 求是否有满足的方案 1≤n,m,k≤1061\leq n,m,k\leq 10^…

后缀数组(讲解)

子串&#xff1a;从原串中选取连续的一段&#xff0c;即子串 空串也是子串 后缀&#xff1a;suf(k)为s(k…n)构成的子串 任何子串都是某个后缀的前缀 最长公共前缀 lcp(suf(i),suf(j)) 问题&#xff1a; 将所有后缀suf(1),suf(2),suf(N)按照字典序从小到大排序 暴力sort N2 …

codeforces1471 D. Strange Definition

D. Strange Definition 大佬题解 由lcm(x,y)xygcd(x,y)lcm(x,y)\frac{xy}{gcd(x,y)}lcm(x,y)gcd(x,y)xy​可知&#xff0c;如果lcm(x,y)gcd(x,y)xygcd2(x,y)\frac{lcm(x,y)}{gcd(x,y)}\frac{xy}{gcd^2(x,y)}gcd(x,y)lcm(x,y)​gcd2(x,y)xy​是完全平方数&#xff0c;那么xyxy…

2018 上海.NET职位围观报告

我一直说我是夏眠动物&#xff0c;如今已经11月份了&#xff0c;差不多也该活过来了&#xff0c;所以我决定写篇文章给各位.NET的支持者们和公司打打气&#xff0c;也算是为社区做点贡献吧。我最近主要干了两件事&#xff1a;让NPOI支持.NET Core&#xff0c;现已发布2.4版本。…

P5437-[XR-2]约定【拉格朗日差值,数学期望】

正题 题目链接:https://www.luogu.com.cn/problem/P5437 题目大意 nnn个点的完全图&#xff0c;连接i,ji,ji,j的边权值为(ij)k(ij)^k(ij)k。随机选出一个生成树&#xff0c;求期望边权和。 1≤n<998244353,1≤k≤1071\leq n<998244353,1\leq k\leq 10^71≤n<99824435…

【模板】分散层叠算法(P6466)

正题 P6466 题目大意 给你 k 个大小为 n 的数组&#xff0c;有q次询问&#xff0c;每次询问回答x在k个数组中的后继的异或和 解题思路 分散层叠模板 code #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #define ll …

后缀数组(后续)

文章目录**后缀数组 Height**两个子串最长公共前缀**求Height数组**比较一个字符串的两个子串的大小关系不同子串的数目出现至少k次的子串的最大长度**总结&#xff1a;**代码&#xff1a;后缀数组 Height 利用后缀数组快速求出2个后缀的lcp长度 lcp:最长公共前缀 lcp(suf(i),…