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

题目意思:首先解释一下d[n]这个函数表示n有多少个因子,百度一下可以知道这个函数是一个非完全积性函数,d[n]=d[i]*d[j]当且仅当i*j=n,且i和j互质,现在求一个[l,r]区间的所有数d[i^k]的和。

思路:比赛场上知道xjb推出了题目给的这个公式d(n​^k​​)=(kc​1​​+1)(kc​2​​+1)...(kc​m​​+1),还是很容易推了的,可能百度也可以找到吧,还是自己推一下比较好。这里说一下是怎么退出来了。首先对于一个数n可以质因分解出n=p1^m1*p2^m2*p3^m3……ps^ms,其中p1,p2,p3…………ps是互不相同的质数,所以每一项都是互质的。

所以d[n]=d[p1^m1]*d[p2^m2]*d[p3^m3]……d[ps^ms]。又因为n^k=[p1^m1*p2^m2*p3^m3……ps^ms]*[p1^m1*p2^m2*p3^m3……ps^ms]…………*[p1^m1*p2^m2*p3^m3……ps^ms],k项相乘,合并一下可以得到n^k=p1^(m1*k)*p2^(m2*k)*p3^(m3*k)…………ps^(ms*k),我们知道对于一个素数有两个因数,而p^k(p为素数)的因子数为k+1,我们可以这样反推这个结论。因为一个数有唯一的质因分解,所以p^k的必然分解成k个p,那么所有的p^t(0<=t<=k)必定都是p^k的因数,而p^k的因数不会再有其他数了,所以一共k+1个因子。

由以上我们证明了d(n​^k​​)=(kc​1​​+1)(kc​2​​+1)...(kc​m​​+1)这个式子,我们现在关键就是把这个式子中的每一个数的每一个c1……cm算出来即可。很明显质因分解计算每个质因子的个数。但是这里用简单的计算不行,所以这道题需要用到区间素数筛,用sqrt(r)内的素数把[l,r]的素数筛出来,那些被筛掉的数必然是被自己的质因子筛掉的。还有一点一个数n的质因子最多只有一个在sqrt(n)的右侧。所以我们建立一个orz数组初始化orz[i-l]=l,然后每次计算一个质因子对他的贡献,就他这些质因子除掉。最后对于那些orz[i-l]!=1的只有两种情况要么是素数,要么是有一个质因子在sqrt(i-l)的右侧,我们只需要再把ans[i-l]*=k+1就好了。

筛素数的时候多筛点,我因为筛少了,导致wa了5发

代码:

 //Author: xiaowuga
#include<cstdio>
#include<cstring>
#include<algorithm>
#define mem(s,ch) memset(s,ch,sizeof(s))
const long long N=1e6+;
const long long mod=;
using namespace std;
typedef long long LL;
bool is_p_small[N];
bool is_p[N];
LL ans[N];
LL l,r,k;
LL orz[N];
LL prime[N];
LL p=;
void sieve(){
mem(is_p_small,true);
is_p_small[]=is_p_small[]=false;
for(LL i=;i<=N-;i++){
if(is_p_small[i]){
prime[p++]=i;
for(LL j=*i;j<=N-;j+=i) is_p_small[j]=false;
}
}
} void sement_sieve(LL a,LL b){
mem(is_p,true);
LL lim=ceil(sqrt(b));
for(LL i=;prime[i]<=lim;i++){
for(LL j=max(2LL,(a+prime[i]-)/prime[i])*prime[i];j<=b;j+=prime[i]){
is_p[j-a]=false;
LL res=;
while(orz[j-a]%prime[i]==){
orz[j-a]/=prime[i];
res++;
}
ans[j-a]=ans[j-a]*(res*k+)%mod;
}
}
}
int main(){
int T;
scanf("%d",&T);
sieve();
while(T--){
scanf("%lld%lld%lld",&l,&r,&k);
for(LL i=;i<=r-l+;i++) {ans[i]=;orz[i]=i+l;}
sement_sieve(l,r+);
LL sum=;
for(LL i=;i<=r-l;i++){
if(orz[i]!=) ans[i]=ans[i]*(k+);
}
for(LL i=;i<=r-l;i++){
sum=(sum+ans[i])%mod;
}
printf("%lld\n",sum);
}
return ;
}

2017 Multi-University Training Contest - Team 4——HDU6069&&Counting Divisors的更多相关文章

  1. 2017 Multi-University Training Contest - Team 4 hdu6069 Counting Divisors

    地址:http://acm.split.hdu.edu.cn/showproblem.php?pid=6069 题目: Counting Divisors Time Limit: 10000/5000 ...

  2. 【2017 Multi-University Training Contest - Team 4】Counting Divisors

    [Link]:http://acm.hdu.edu.cn/showproblem.php?pid=6069 [Description] 定义d(i)为数字i的因子个数; 求∑rld(ik) 其中l,r ...

  3. 2017 Multi-University Training Contest - Team 9 1005&&HDU 6165 FFF at Valentine【强联通缩点+拓扑排序】

    FFF at Valentine Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  4. 2017 Multi-University Training Contest - Team 9 1004&&HDU 6164 Dying Light【数学+模拟】

    Dying Light Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Tot ...

  5. 2017 Multi-University Training Contest - Team 9 1003&&HDU 6163 CSGO【计算几何】

    CSGO Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Subm ...

  6. 2017 Multi-University Training Contest - Team 9 1002&&HDU 6162 Ch’s gift【树链部分+线段树】

    Ch’s gift Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total S ...

  7. 2017 Multi-University Training Contest - Team 9 1001&&HDU 6161 Big binary tree【树形dp+hash】

    Big binary tree Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  8. 2017 Multi-University Training Contest - Team 1 1003&&HDU 6035 Colorful Tree【树形dp】

    Colorful Tree Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  9. 2017 Multi-University Training Contest - Team 1 1006&&HDU 6038 Function【DFS+数论】

    Function Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Total ...

随机推荐

  1. error while loading shared libraries *.so.*

    转自 http://my.oschina.net/u/561492/blog/192341 ubuntu12.04-64位编译Android4.2时出现问题:error while loading s ...

  2. 怎么使用Less/Sass编译工具koala

    怎么使用Less/Sass编译工具koala 如何使用Less/Sass编译工具koala 一.SASS调试插件的方法 如需调试功能,请在编译输出的时候输出debug信息,那样解析的css文件中就会包 ...

  3. jmap 查看内存使用直方图

    jps   -- 查看进程号 jmap -histo pid  查看堆内存中的对象数目.大小统计直方图, 如果带上live则表示先进行一次fullgc 再统计内存使用情况,如下: jmap -hist ...

  4. Java compiler level does not match the version of the installed Java project facet 的解决方案

     今天将MyEclipse升级到 9.1 后,打开原来的工作空间,原来所有的项目都前面都显示了一个小叉叉,代码中却没有任何错误.于从 problems 视图中查看错误信息,错误信息的"D ...

  5. Parallelism , Partitioner

    转:spark通过合理设置spark.default.parallelism参数提高执行效率 spark中有partition的概念(和slice是同一个概念,在spark1.2中官网已经做出了说明) ...

  6. hive中关键字作为列名的方法

    hive中有很多关键字,直接作为列名,会出错的 例如 下面 user就是关键字,作为字段时报以下错误. 解决方案: 使用·· (ESC下面的那个键,点号)两个符号包裹即可.

  7. DELETE 语句用于删除表中的行。

    DELETE FROM 表名称 WHERE 列名称 = 值

  8. mysql -- 一次执行多条sql语句

    最近要做一个软件升级,其中涉及到数据库表字段的变动(新增或删除或修改),所有的关于数据库的变动的sql语句都是存放在Sqlupdate.sql文件中,每次升级的时候都需要执行一次Sqlupdate.s ...

  9. 【NOIP模拟题】Permutation(dp+高精度)

    首先我们可以这样想: 设状态f[i, j]表示1-i序列有j个'<'的方案数 那么考虑转移 因为i比i-1大,所以可以考虑从i-1来转移.首先i是要插入1-i-1这个序列的,所以我们可以思考插入 ...

  10. 阿里Java开发手冊之编程规约

    对于程序猿来说,编程规范能够养成良好的编程习惯,提高代码质量,减少沟通成本.就在2月9号,阿里出了一份Java开发手冊(正式版),分为编程规约.异常日志.MySQL规约,project规约.安全规约五 ...