Description###

我们知道,从区间[L,H](L和H为整数)中选取N个整数,总共有(H-L+1)^N种方案。小z很好奇这样选出的数的最大公约数的规律,他决定对每种方案选出的N个整数都求一次最大公约数,以便进一步研究。然而他很快发现工作量太大了,于是向你寻求帮助。你的任务很简单,小z会告诉你一个整数K,你需要回答他最大公约数刚好为K的选取方案有多少个。由于方案数较大,你只需要输出其除以1000000007的余数即可。

Input###

输入一行,包含4个空格分开的正整数,依次为N,K,L和H。

Output###

输出一个整数,为所求方案数。

Sample Input###

2 2 2 4

Sample Output###

3

HINT###

样例解释

所有可能的选择方案:(2, 2), (2, 3), (2, 4), (3, 2), (3, 3), (3, 4), (4, 2), (4, 3), (4, 4)

其中最大公约数等于2的只有3组:(2, 2), (2, 4), (4, 2)

对于100%的数据,1<=N,K<=109,1<=L<=H<=109,H-L<=10^5


想法##

最初的想法是莫比乌斯反演,但写了一半发现好麻烦,还要杜教筛之类的。。。

于是放弃!上普通容斥!

我们发现 \(H-L \leq 10^5\) ,那对于这个范围内,任意两不同的数的gcd \(\leq 10^5\)

(这个应该还是挺显然的。这两个数的差一定是它们gcd的倍数)

我们先把L与H处理一下,都除以K,将问题转变为求某一区间\([l,r]\)内选N个数gcd为1的方案数。

设 \(f[i]\) 表示该区间内选N个数(这N个数不全相同),gcd为i的方案数 (一会儿我会解释为什么要N个数不全相同)

那么 $f[i]=[r/i-l/i]^n - [r/i-l/i] - \sum\limits_{i|j} f[j] $

其中减去的 $[r/i-l/i] $ 便是N个数都相同的情况。

最后需要特判一下是否N个数可以都取K,若可以答案为\(f[1]+1\),否则为\(f[1]\)

好,现在解释一下为什么\(f[i]\)中选的N个数不全相同(想了好久才明白qwq)

一开始我想的是,计算\(f[i]\)时不需减掉 \([r/i-l/i]\),因为所有 \(f[i]\) 都带上 \((i,i,i,i,…)\) ,在 $ - \sum\limits_{i|j} f[j]$ 时肯定会被消掉。

可是,对于区间\([l,r]\)中的任意一个数x, \((x,x,x,x,x…)\) 的gcd为x,可能是超过\(10^5\)的。

而我们的\(f[i]\)最多只到\(10^5\),所以如果\(f[i]\)包括N个数都相同的情况的话,会有一些 \((x,x,x,x,…)\) 没有被减掉

而我们又知道,若N个数都相同且gcd为K,那只有这N个数都为K这一种情况。对这种情况特判一下就可以了。


一个小总结##

莫比乌斯反演与普通容斥的异同:

对于这道题的条件,两者都可以由 \(F(i)=f(i)+f(2i)+f(3i)+…\) 的式子写成,其中\(F(i)\)极其好求,而\(f(i)\)是我们需要的答案。

莫比乌斯反演是只通过\(F()\)求\(f()\),用到莫比乌斯函数

而普通容斥的做法就是递推,通过\(F()\)及\(f()\) 求\(f()\)

一般来说莫比乌斯反演时间复杂度可以优化到\(O(\sqrt{n})\),比普通容斥快;而普通容斥比莫比乌斯反演好写许多。

所以要具体问题具体分析,再决定用哪种做法。


代码##

#include<cstdio>
#include<iostream>
#include<algorithm> #define P 1000000007 using namespace std; typedef long long ll;
const int N = 100005; ll Pow_mod(int x,int y){
ll ret=1;
while(y){
if(y&1) ret=(ret*x)%P;
x=((ll)x*x)%P; //别忘了临时转long long !!!
y>>=1;
}
return ret;
} int n,K,L,H,l,r,m;
ll f[N]; int main()
{
scanf("%d%d%d%d",&n,&K,&L,&H);
l=(L-1)/K; r=H/K;
m=r-l; int x;
for(int i=m;i>0;i--){
x=r/i-l/i;
if(x<=0) continue;
f[i]=(Pow_mod(x,n)-x+P)%P;
for(int j=i*2;j<=m;j+=i)
f[i]=(f[i]-f[j]+P)%P;
}
if(L<=K && K<=H) f[1]=(f[1]+1)%P;
printf("%lld\n",f[1]); return 0;
}

[bzoj3930] [洛谷P3172] [CQOI2015] 选数的更多相关文章

  1. 洛谷P3172 [CQOI2015]选数(容斥)

    传送门 首先,进行如下处理 如果$L$是$K$的倍数,那么让它变成$\frac{L}{K}$,否则变成$\frac{L}{K}+1$ 把$H$变成$\frac{H}{K}$ 那么,现在的问题就变成了在 ...

  2. 【洛谷p1036】选数

    (一定要声明我太蒟了,这个题扣了一上午……) 算法标签: …… dfs真的不是我所擅长的qwq,这道题的思路其实很简单,就是先dfs搜索所有可能的和,然后判断是不是质数.说着好说,然鹅并不好写: 第一 ...

  3. P3172 [CQOI2015]选数(莫比乌斯反演)

    [题目链接] https://www.luogu.org/problemnew/show/P3172 [题解] https://www.luogu.org/blog/user29936/solutio ...

  4. luogu P3172 [CQOI2015]选数

    传送门 颓了一小时柿子orz 首先题目要求的是\[\sum_{x_1=l}^{r}\sum_{x_2=l}^{r}...\sum_{x_n=l}^{r}[gcd(x_1,x_2...x_n)=k]\] ...

  5. 洛谷 [CQOI2015]选数 解题报告

    [CQOI2015]选数 题目描述 我们知道,从区间\([L,H]\)(\(L\)和\(H\)为整数)中选取\(N\)个整数,总共有\((H-L+1)^N\)种方案. 小\(z\)很好奇这样选出的数的 ...

  6. 【BZOJ3930】[CQOI2015]选数 莫比乌斯反演

    [BZOJ3930][CQOI2015]选数 Description 我们知道,从区间[L,H](L和H为整数)中选取N个整数,总共有(H-L+1)^N种方案.小z很好奇这样选出的数的最大公约数的规律 ...

  7. bzoj3930[CQOI2015]选数 容斥原理

    3930: [CQOI2015]选数 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1383  Solved: 669[Submit][Status] ...

  8. BZOJ 3930: [CQOI2015]选数 递推

    3930: [CQOI2015]选数 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pro ...

  9. [CQOI2015]选数(莫比乌斯反演,杜教筛)

    [CQOI2015]选数(luogu) Description 题目描述 我们知道,从区间 [L,H](L 和 H 为整数)中选取 N 个整数,总共有 (H-L+1)^N 种方案. 小 z 很好奇这样 ...

随机推荐

  1. 2018.10.26 浪在ACM 集训队第二次测试赛

    2018.10.26 浪在ACM 集训队第二次测试赛 整理人:苗学林 A海港 参考博客:[1]:李继朋https://www.cnblogs.com/violet-acmer/p/9859006.ht ...

  2. 【37.48%】【hdu 2587】How far away ?(3篇文章,3种做法,LCA之ST算法(RMQ))

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

  3. dotnet 线程静态字段

    在 dotnet 程序提供了一个好用的特性,可以让字段作为线程的静态字段,也就是在相同线程的所有代码访问的静态字段是相同对象,但不同线程访问的时候是不同的 在 .NET 程序可以使用 ThreadSt ...

  4. linux 搭建jenkins

    一.什么是持续集成? (1)Continuous integration(CI) 持续集成是一种软件开发实践,即团队开发成员经常集成他们的工作,通常每个成员至少集成一次,也就意味着每天可能会发生多次集 ...

  5. 如何在MPlayer上支持RTSP

    http://www.live555.com/mplayer/ 请按照如下步骤 下载 "LIVE555 Streaming Media" l的库的源码, 解压后 将"li ...

  6. 阿里面试官让我讲讲Unicode,我讲了3秒说没了,面试官说你可真菜

    本文首发于微信公众号:程序员乔戈里 乔哥:首先说说什么是Unicode.码点吧~要想搞懂,这些概念必须清楚 什么是Unicode? 下图来自http://www.unicode.org/standar ...

  7. 分布式事务框架-seata初识

    一.事务与分布式事务 事务,在数据库中指的是操作数据库的最小单位,往大了看,事务是应用程序中一系列严密的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消. 那为什么会有分布式事务呢 ...

  8. 从零开始のcocos2dx生活(十)ScrollView

    目录 简介 基础变量 ScrollViewDelegate Direction _dragging _container _touchMoved _bounceable _touchLength 方法 ...

  9. $Poj2083/AcWing118\ Fractal$ 模拟

    $AcWing$ $Sol$ 一年前做过差不多的南蛮图腾,当时做出来还是很有成就感的$OvO$ $N<=7$,就是模拟模拟,预处理一下,$over$ $Code$ #include<bit ...

  10. 在 Win7、Win10 家庭版中启用组策略(gpedit.msc)

    Windows 家庭版并没有组策略,对于计算机维护.优化和设置非常不方便.使用以下批处理可以在不安装专业版.旗舰版的情况下启用组策略. 一.新建一个批处理脚本 1 @echo off 2 3 push ...