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≤10^9,1≤L≤H≤10^9,H-L≤10^5

题解

设 $F(x)$ 为 $x\mid gcd$ 的个数, $f(x)$ 为 $gcd=x$ 的个数。

\begin{aligned}F(x)&=\sum_{x\mid d}f(d)\\\Rightarrow f(x)&=\sum_{x\mid d}\mu\left(\frac{d}{x}\right)F(d)\end{aligned}

对于输入 $(N,K,L,H)$ 我们记 $\left\lceil\frac{L}{K}\right\rceil$ 为 $l$ ,记 $\left\lfloor\frac{H}{K}\right\rfloor$ 为 $h$ 。

提出 $K$ ,答案就是 $$f(1)=\sum_{i=1}^{h}\mu(i)F(i)$$

显然 $F(i)=\left(\left\lfloor\frac{h}{i}\right\rfloor-\left\lfloor\frac{l-1}{i}\right\rfloor\right)^N$

由于 $h$ 很大,我们还是不能枚举这个 $i$ 。考虑到这样一个问题:当 $i$ 很大时 $\left\lfloor\frac{h}{i}\right\rfloor-\left\lfloor\frac{l-1}{i}\right\rfloor$ 会变成 $0$ 或 $1$ 。实际上只要 $i>h-l$ 数值就为 $0$ 或 $1$ 了。

那么现在答案就变成了 \begin{aligned}&\sum_{i=1}^{h-l}\mu(i)\left(\left\lfloor\frac{h}{i}\right\rfloor-\left\lfloor\frac{l-1}{i}\right\rfloor\right)^N+\sum_{i=h-l+1}^h\mu(i)\left\lfloor\frac{h}{i}\right\rfloor-\left\lfloor\frac{l-1}{i}\right\rfloor\\=&\sum_{i=1}^{h-l}\mu(i)\left(\left\lfloor\frac{h}{i}\right\rfloor-\left\lfloor\frac{l-1}{i}\right\rfloor\right)^N+\sum_{i=1}^h\mu(i)\left\lfloor\frac{h}{i}\right\rfloor-\left\lfloor\frac{l-1}{i}\right\rfloor-\sum_{i=1}^{h-l}\mu(i)\left\lfloor\frac{h}{i}\right\rfloor-\left\lfloor\frac{l-1}{i}\right\rfloor\end{aligned}

我们观察到式子 $\sum\limits_{i=1}^h\mu(i)\left\lfloor\frac{h}{i}\right\rfloor-\left\lfloor\frac{l-1}{i}\right\rfloor$ 的含义就是 $l\sim r$ 区间内有是否有值为 $1$ ,所以等价于 $[L\leq K\wedge K\leq H]$ 。

所以 $$ans=\sum_{i=1}^{h-l}\mu(i)\left(\left(\left\lfloor\frac{h}{i}\right\rfloor-\left\lfloor\frac{l-1}{i}\right\rfloor\right)^N-\left(\left\lfloor\frac{h}{i}\right\rfloor-\left\lfloor\frac{l-1}{i}\right\rfloor\right)\right)+[L\leq K\wedge K\leq H]$$

 //It is made by Awson on 2018.1.24
#include <set>
#include <map>
#include <cmath>
#include <ctime>
#include <queue>
#include <stack>
#include <cstdio>
#include <string>
#include <vector>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define Abs(a) ((a) < 0 ? (-(a)) : (a))
#define Max(a, b) ((a) > (b) ? (a) : (b))
#define Min(a, b) ((a) < (b) ? (a) : (b))
#define Swap(a, b) ((a) ^= (b), (b) ^= (a), (a) ^= (b))
#define writeln(x) (write(x), putchar('\n'))
#define lowbit(x) ((x)&(-(x)))
using namespace std;
const int N = 1e5;
const int MOD = ;
void read(int &x) {
char ch; bool flag = ;
for (ch = getchar(); !isdigit(ch) && ((flag |= (ch == '-')) || ); ch = getchar());
for (x = ; isdigit(ch); x = (x<<)+(x<<)+ch-, ch = getchar());
x *= -*flag;
}
void write(LL x) {
if (x > ) write(x/);
putchar(x%+);
} int n, k, l, h, mu[N+];
int isprime[N+], prime[N+], tot; void get_mu() {
memset(isprime, , sizeof(isprime)); isprime[] = , mu[] = ;
for (int i = ; i <= N; i++) {
if (isprime[i]) prime[++tot] = i, mu[i] = -;
for (int j = ; j <= tot && i*prime[j] <= N; j++) {
isprime[i*prime[j]] = ;
if (i%prime[j]) mu[i*prime[j]] = -mu[i];
else {mu[i*prime[j]] = ; break; }
}
}
}
int quick_pow(int a, int b) {
int ans = ;
while (b) {
if (b&) ans = (LL)ans*a%MOD;
a = (LL)a*a%MOD, b >>= ;
}
return ans;
}
void work() {
get_mu(); read(n), read(k), read(l), read(h);
int flag = (l <= k && k <= h), ans = ;
l = ceil(.*l/k), h = (h/k);
for (int i = ; i <= h-l; i++) ans = (ans+(LL)mu[i]*quick_pow(h/i-(l-)/i, n)%MOD)%MOD;
for (int i = ; i <= h-l; i++) ans = (ans-(LL)mu[i]*(h/i-(l-)/i)%MOD)%MOD;
writeln((ans+flag+MOD)%MOD);
}
int main() {
work();
return ;
}

最新文章

  1. iOS编程中遇到的问题
  2. MySQL sharding的几个参考地址
  3. Java简单类——双向一对多映射
  4. position:absolute和float会隐式的改变display类型
  5. linux系统和依赖包常用下载地址
  6. Node.js爬虫数据抓取 -- 问题总结
  7. hdu 4616 Game
  8. 249. Group Shifted Strings
  9. java常用指令
  10. Miller-Rabin质数测试
  11. 扔掉log4j、log4j2,自己动手实现一个多功能日志记录框架,包含文件,数据库日志写入,实测5W+/秒日志文件写入,2W+/秒数据库日志写入,虽然它现在还没有logback那么强大
  12. linux中python3安装和使用
  13. mybatis 动态sql和参数
  14. javase基础回顾(三) 动态代理
  15. php通过某个日期段的周几,获取选中周几对应的日期
  16. myBatis框架之入门(一)
  17. 【洛谷p1926】小书童——蚂蚁大战
  18. 基于jQuery实现的腾讯互动娱乐网站特效
  19. eclipse快速向下复制行
  20. 使用VMWareWorkstation10搭建学习环境笔记

热门文章

  1. Java虚拟机之Java内存区域
  2. C#简单入门
  3. JavaScript(第三十三天)【总结:封装基础前端框架】
  4. 【alpha冲刺】随笔合集
  5. Alpha冲刺No.6
  6. Alpha冲刺Day2
  7. 张金禹 C语言--第0次作业
  8. Flask 学习 五 电子邮件
  9. python之路--day10-闭包函数
  10. ASP.NET MVC 5 SmartCode Scaffolding for Visual Studio.Net