樱花(约数之和)
Posted li_wen_zhuo
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了樱花(约数之和)相关的知识,希望对你有一定的参考价值。
题目描述
给定一个整数 n,求有多少正整数数对 (x,y) 满足 1/x+1/y=1/n!。
输入格式
一个整数 n。
输出格式
一个整数,表示满足条件的数对数量。
答案对 109+7 取模。
数据范围
1≤n≤106
输入样例
2
输出样例
3
样例解释
共有三个数对 (x,y) 满足条件,分别是 (3,6),(4,4),(6,3)。
题目分析
首
先
我
们
先
对
公
式
进
行
一
下
化
简
:
首先我们先对公式进行一下化简:
首先我们先对公式进行一下化简:
1
/
x
+
1
/
y
=
1
/
n
!
1/x+1/y=1/n!
1/x+1/y=1/n!
(
x
+
y
)
/
(
x
∗
y
)
=
1
/
n
!
(x+y)/(x*y)=1/n!
(x+y)/(x∗y)=1/n!
(
x
+
y
)
∗
n
!
=
x
∗
y
(x+y)*n!=x*y
(x+y)∗n!=x∗y
x
∗
n
!
=
y
(
x
−
n
!
)
x*n!=y(x-n!)
x∗n!=y(x−n!)
y
=
(
x
∗
n
!
)
/
(
x
−
n
!
)
y=(x*n!)/(x-n!)
y=(x∗n!)/(x−n!)
y
=
(
x
−
n
!
+
n
!
)
∗
n
!
/
(
x
−
n
!
)
y=(x-n!+n!)*n!/(x-n!)
y=(x−n!+n!)∗n!/(x−n!)
y
=
(
x
−
n
!
)
∗
n
!
/
(
x
−
n
!
)
+
n
!
2
/
(
x
−
n
!
)
y=(x-n!)*n!/(x-n!)+n!^2/(x-n!)
y=(x−n!)∗n!/(x−n!)+n!2/(x−n!)
y
=
n
!
+
n
!
2
/
(
x
−
n
!
)
y=n!+n!^2/(x-n!)
y=n!+n!2/(x−n!)
我
们
可
以
来
分
析
一
下
这
个
公
式
:
我们可以来分析一下这个公式:
我们可以来分析一下这个公式:
1
、
x
与
y
是
一
一
对
应
的
。
1、x与y是一一对应的。
1、x与y是一一对应的。
2
、
根
据
题
目
,
x
与
y
都
必
须
为
整
数
。
那
么
如
果
y
要
为
整
数
,
n
!
2
/
(
x
−
n
!
)
就
必
须
要
为
整
数
。
2、根据题目,x与y都必须为整数。那么如果y要为整数,n!^2/(x-n!) 就必须要为整数。
2、根据题目,x与y都必须为整数。那么如果y要为整数,n!2/(x−n!)就必须要为整数。
3
、
当
x
−
n
!
为
n
!
2
的
约
数
时
,
n
!
2
/
(
x
−
n
!
)
为
整
数
。
3、当 x-n! 为n!^{2}的约数时,n!^{2}/(x-n!) 为整数。
3、当x−n!为n!2的约数时,n!2/(x−n!)为整数。
又 因 为 x 可 以 取 到 任 意 整 数 , 由 此 我 们 可 以 推 出 : ( x , y ) 的 对 数 即 为 n ! 2 约 数 的 个 数 。 然 后 我 们 只 需 要 套 用 约 数 个 数 又因为x可以取到任意整数,由此我们可以推出:(x,y)的对数即为n!^2约数的个数。然后我们只需要套用约数个数 又因为x可以取到任意整数,由此我们可以推出:(x,y)的对数即为n!2约数的个数。然后我们只需要套用约数个数 公 式 , 求 出 n ! 2 的 约 数 和 即 可 。 公式,求出n!^2的约数和即可。 公式,求出n!2的约数和即可。
注
:
求
约
数
个
数
的
公
式
为
注:求约数个数的公式为
注:求约数个数的公式为
N
=
p
1
a
1
∗
p
2
a
2
∗
p
3
a
3
∗
…
…
∗
p
n
a
n
N=p1^{a1}*p2^{a2}*p3^{a3}*……*pn^{an}
N=p1a1∗p2a2∗p3a3∗……∗pnan
n
u
m
N
=
(
a
1
+
1
)
∗
(
a
2
+
1
)
∗
(
a
3
+
1
)
∗
…
…
∗
(
a
n
+
1
)
numN=(a1+1)*(a2+1)*(a3+1)*……*(an+1)
numN=(a1+1)∗(a2+1)∗(a3+1)∗……∗(an+1)
代码如下
#include <iostream>
#include <cstdio>
#include <cmath>
#include <string>
#include <cstring>
#include <map>
#include <queue>
#include <vector>
#include <bitset>
#include <set>
#include <algorithm>
#define LL long long
#define ULL unsigned long long
#define PII pair<int,int>
#define x first
#define y second
using namespace std;
const int N=1e6+5,mod=1e9+7;
int prime[N],cnt;
bool st[N];
void init(int n) //线筛模板
{
for(int i=2;i<=n;i++)
{
if(!st[i]) prime[cnt++]=i;
for(int j=0;prime[j]*i<=n;j++)
{
st[prime[j]*i]=true;
if(i%prime[j]==0) break;
}
}
}
int main()
{
int n;
cin>>n;
init(n);
int ans=1;
for(int i=0;i<cnt;i++) //枚举所有素数
{
int num=0; //记录n!中有多少个素数prime[i]
for(int j=n;j;j/=prime[i]) num+=j/prime[i];
ans=(LL)ans*(2*num+1)%mod; //因为求的是n!^2的约数,因此这里要乘(2*num+1)
}
cout<<ans<<endl;
return 0;
}
以上是关于樱花(约数之和)的主要内容,如果未能解决你的问题,请参考以下文章