数论——[Violet]樱花

题意:求方程 1/X+1/Y=1/(N!) 的正整数解的组数,其中N≤10^6。



设n!=z,y=z+d

1/x+1/y=1/z

1/x+1/(z+d)=1/z

(x+z+d)/(x*z+dx)=1/z

z(x+z+d)=x*z+dx

z^2+dz=dx

x=z^2/d+z

所以只要求有z^2有多少约数(即d的集合元素个数)即可


 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 #define N 1000003
 4 #define mo 1000000007
 5 #define ll long long
 6 using namespace std;
 7 int n,pri[N],mp[N],num[N],p[N];
 8
 9 void oula()
10 {
11     for (int i=2;i<=N;i++)
12     {
13         if (!p[i]) pri[++pri[0]]=i,mp[i]=pri[0];
14         for (int j=1;i*pri[j]<=N&&j<=pri[0];j++)
15         {
16             p[i*pri[j]]=1;
17             if (i%pri[j]==0) break;
18         }
19     }
20 }
21 void cal(int x)
22 {
23     for (int i=1;pri[i]*pri[i]<=x;i++)
24     {
25         if (x%pri[i]==0)
26         {
27             while (x%pri[i]==0) num[i]++,x/=pri[i];
28         }
29
30     }
31     if (x>1) num[mp[x]]++;
32 }
33 int main()
34 {
35     scanf("%d",&n);
36     oula();
37     for (int i=1;i<=n;i++)
38         cal(i);
39     ll ans=1;
40     for (int i=1;i<=pri[0];i++) ans=ans*(ll)(num[i]*2+1)%mo;//计算
41     printf("%lld",ans);
42     return 0;
43 }

原文地址:https://www.cnblogs.com/71-111/p/9330886.html

时间: 2024-08-30 12:29:25

数论——[Violet]樱花的相关文章

P4167 [Violet]樱花

题目背景 又到了一年樱花盛开的时节.Vani 和妹子一起去看樱花的时候,找到了一棵大大的樱 花树,上面开满了粉红色的樱花.Vani 粗略估计了一下,一共有足足  n! 片花瓣. Vani 轻柔地对她说:“你知道吗?这里面的一片花瓣代表着你,我从里面随机摘一片,能和你相遇的概率只有1/n!那么小.我该是多么的幸运,才让你今天这么近地站在我面前. 相信我,我一定会把这亿万分之一的缘分变为永远.” 粉红的樱花漫天飞舞,妹子瞬间被 Vani 感动了.她轻轻地牵起了他的手,和他相依而 坐.这时,她突然看到

【Copy自某谷题解】P1445 【[Violet]樱花】

做了题还是忍不住要写一发题解,感觉楼下的不易懂啊. 本题解使用latex纯手写精心打造. 题意:求\(\frac{1}{x}+\frac{1}{y}=\frac{1}{n!}\)的正整数解总数. 首先,不会线筛素数的先去做下LuoguP3383. 开始推导. \[\frac{1}{x}+\frac{1}{y}=\frac{1}{n!}\] 那么\(\frac{1}{x}\)和\(\frac{1}{y}\)肯定是小于\(\frac{1}{n!}\)的.所以\(x\)和\(y\)肯定都是大于\(n!

Bzoj2721 [Violet]樱花(筛法)

题面 题解 首先化一下式子 $$ \frac 1x+\frac 1y=\frac 1{n!} \Rightarrow \frac {x+y}{xy}=\frac 1{n!} \Rightarrow (x+y)n!=xy \\ \Rightarrow(n!-x)+(n!-y)=(n!)^2 $$ 看到最后一个式子,由于$n!$是唯一确定的,所以只要确定了$x$,$y$也是确定的,而且是唯一确定的一组$(x,y)$. 根据唯一分解定理,$n!=p_1^{k_1}p_2^{k_2}...p_m^{k_

Luogu1445 [Violet]樱花

题面 题解 $$ \frac 1x + \frac 1y = \frac 1{n!} \\ \frac{x+y}{xy}=\frac 1{n!} \\ xy=n!(x+y) \\ xy-n!(x+y)=0 \\ (x-n!)(y-n!)=(n!)^2 \\ $$ 因为确定$(x-n!),(y-n!)$就能确定$x,y$,所以答案就是$d((n!)^2)$ 代码 #include<cstdio> #include<cstring> #include<cctype> #in

解题报告:luogu P1445

题目链接:P1445 [Violet]樱花 数学题真的不会了,只推出了浅显的一步,真的菜. 易得到: \[xy=(x+y)n! \] 移项然后两边同时间上\((n!)^2\),构造平方数: \[(n!)^2=(n!)^2+(x+y)n!-xy \] 右边十字相乘因式分解: \[(n!)^2=(n!-x)(n!-y) \] 设\(a=n!-x,b=n!-y\),那么: \[(n!)^2=ab \] 显然\(a,b\)为\((n!)^2\)的因子,且\(a,b\)与\(x,y\)一一对应,那么我们只

【bzoj2721】[Violet 5]樱花 数论

题目描述 输入 输出 样例输入 2 样例输出 3 题解 数论 设1/x+1/y=1/m,那么xm+ym=xy,所以xy-xm-ym+m^2=m^2,所以(x-m)(y-m)=m^2. 所以解的数量就是m^2的约数个数. 所以只需要算出n!中每个素数的出现次数即可. 我们可以先快筛出1~n的素数,然后考虑每个素数出现的次数. 而p出现的次数为包含p^1的数的个数+包含p^2的数的个数+...+包含p^k的数的个数,我们可以迭代来求. 最后把它们乘2加1再乘到一起即可. #include <cstd

BZOJ 2721 Violet 5 樱花 数论

题目大意:给定n,求有多少正整数数对(x,y)满足1x+1y=1n! 由于x,y>0,故显然有y>n! 不妨设y=n!+t(t>0),那么有 1x+1n!+t=1n! 化简后得到 n!(n!+t)+x(n!)=x(n!+t) x=(n!)2t+n! 故答案为d((n!)2) #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #defin

【筛法求素数】【质因数分解】bzoj2721 [Violet 5]樱花

http://www.cnblogs.com/rausen/p/4138233.html #include<cstdio> #include<iostream> using namespace std; #define MOD 1000000007 int n; bool Not[1000001]; int pr[1000001],e,ci[1000001]; void shai() { Not[1]=1; for(int i=2;i<=1000;++i) if(!Not[i

2721: [Violet 5]樱花|约数个数

先跪一发题目背景QAQ 显然x,y>n!,然后可以设y=n!+d 原式子可以化简成 x=n!2d+n! 那么解的个数也就是n!的因子个数,然后线性筛随便搞一搞 #include<cstdio> #include<cstdlib> #include<cstring> #include<cmath> #include<queue> #include<vector> #include<set> #include<ma