【BZOJ 3560】 3560: DZY Loves Math V (欧拉函数)

时间:2021-12-31 20:14:50

3560: DZY Loves Math V

Time Limit: 10 Sec  Memory Limit: 256 MB
Submit: 241  Solved: 133

Description

给定n个正整数a1,a2,…,an,求

【BZOJ 3560】 3560: DZY Loves Math V (欧拉函数)

的值(答案模10^9+7)。

Input

第一行一个正整数n。
接下来n行,每行一个正整数,分别为a1,a2,…,an。

Output

仅一行答案。

Sample Input

3
6
10
15

Sample Output

1595

HINT

1<=n<=10^5,1<=ai<=10^7。共3组数据。

Source

【分析】

  好好想这题就不难。

  phi是积性函数,把i1*i2*..in分解质因数,那么答案就是Πphi[xxx]【BZOJ 3560】 3560: DZY Loves Math V (欧拉函数)

  【BZOJ 3560】 3560: DZY Loves Math V (欧拉函数)其中一个质数p对答案的贡献就是

  【BZOJ 3560】 3560: DZY Loves Math V (欧拉函数)

  因为phi[p^n]=p^n*(p-1)/p 而phi[1]=1

  所以要减一再加一smd

  然后就暴力了。

 #include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define Maxn 100010
#define LL long long
#define Mod 1000000007 int pri[Maxn],pl;
bool vis[Maxn]; struct node
{
int x,y;
}t[*Maxn];int len; bool cmp(node x,node y) {return (x.x==y.x)?(x.y<y.y):(x.x<y.x);} void init()
{
pl=;
memset(vis,,sizeof(vis));
for(int i=;i<=Maxn-;i++)
{
if(!vis[i]) pri[++pl]=i;
for(int j=;j<=pl;j++)
{
if(pri[j]*i>Maxn-) break;
vis[pri[j]*i]=;
if(i%pri[j]==) break;
}
}
} void ins(int x)
{
for(int i=;pri[i]*pri[i]<=x;i++) if(x%pri[i]==)
{
t[++len].x=pri[i];t[len].y=;
while(x%pri[i]==) t[len].y++,x/=pri[i];
}
if(x!=) t[++len].x=x,t[len].y=;
} int sum[Maxn]; LL qpow(int x,int b)
{
LL xx=(LL)x,ans=;
while(b)
{
if(b&) ans=(ans*xx)%Mod;
xx=(xx*xx)%Mod;
b>>=;
}
return ans;
} int main()
{
init();
int n;
scanf("%d",&n);
len=;
for(int i=;i<=n;i++)
{
int x;
scanf("%d",&x);
ins(x);
}
sort(t+,t++len,cmp);
int j;
LL ans=;
for(int i=;i<=len;i=j+)
{
j=i;
while(t[j].x==t[i].x&&j<=len) j++;j--;
sum[]=;for(int k=;k<=t[j].y;k++) sum[k]=(sum[k-]*t[i].x)%Mod;
for(int k=;k<=t[j].y;k++) sum[k]+=sum[k-];
LL now=;
for(int k=i;k<=j;k++) now=(now*sum[t[k].y])%Mod;
ans=ans*((now-)%Mod*(t[i].x-)%Mod*qpow(t[i].x,Mod-)%Mod+)%Mod;
}
printf("%lld\n",ans);
return ;
}

2017-03-23 19:39:20

【BZOJ 3560】 3560: DZY Loves Math V (欧拉函数)的更多相关文章

  1. &lbrack;BZOJ3560&rsqb;DZY Loves Math V&lpar;欧拉函数&rpar;

    https://www.cnblogs.com/zwfymqz/p/9332753.html 由于欧拉函数是积性函数,可以用乘法分配律变成对每个质因子分开算最后乘起来.再由欧拉函数公式和分配律发现就是 ...

  2. 【bzoj3560】DZY Loves Math V 欧拉函数

    题目描述 给定n个正整数a1,a2,…,an,求 的值(答案模10^9+7). 输入 第一行一个正整数n. 接下来n行,每行一个正整数,分别为a1,a2,…,an. 输出 仅一行答案. 样例输入 3 ...

  3. bzoj 3560 DZY Loves Math V - 线性筛 - 扩展欧几里得算法

    给定n个正整数a1,a2,…,an,求 的值(答案模10^9+7). Input 第一行一个正整数n. 接下来n行,每行一个正整数,分别为a1,a2,…,an. Output 仅一行答案. Sampl ...

  4. 【BZOJ】3309&colon; DZY Loves Math 莫比乌斯反演优化

    3309: DZY Loves Math Description 对于正整数n,定义f(n)为n所含质因子的最大幂指数.例如f(1960)=f(2^3 * 5^1 * 7^2)=3, f(10007) ...

  5. BZOJ3560 &colon; DZY Loves Math V

    因为欧拉函数是非完全积性函数,所以可以考虑对每个数进行分解质因数,将每个质数的解乘起来即可. 对于一个质数$p$,设它在各个数中分别出现了$b_1,b_2,...b_n$次,那么由生成函数和欧拉函数的 ...

  6. 【BZOJ3960】DZY Loves Math V(数论)

    题目: BZOJ3560 分析: orz跳瓜. 欧拉函数的公式: \[\phi(n)=n(\prod \frac{p_i-1}{p_i})\] 其中 \(p_i\) 取遍 \(n\) 的所有质因子. ...

  7. &lbrack;BZOJ4026&rsqb;dC Loves Number Theory 欧拉函数&plus;线段树

    链接 题意:给定长度为 \(n\) 的序列 A,每次求区间 \([l,r]\) 的乘积的欧拉函数 题解 考虑离线怎么搞,将询问按右端点排序,然后按顺序扫这个序列 对于每个 \(A_i\) ,枚举它的质 ...

  8. 【BZOJ】2005&colon; &lbrack;Noi2010&rsqb;能量采集(欧拉函数&plus;分块)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2005 首先和某题一样应该一样可以看出每个点所在的线上有gcd(x,y)-1个点挡着了自己... 那么 ...

  9. &lbrack;bzoj 2190&rsqb;&lbrack;SDOI2008&rsqb;仪仗队(线性筛欧拉函数)

    题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2190 分析:就是要线性筛出欧拉函数... 直接贴代码了: memset(ans,,sizeof ...

随机推荐

  1. 8&period;adr与ldr伪指令的区别

    ldr和adr都是伪指令,区别是ldr是长加载.adr是短加载. 重点:adr指令加载符号地址,加载的是运行时地址: ldr指令加载符号地址时,加载的是链接地址.

  2. 关于在EXCEL中输入01-01-01被转换为2001&sol;1&sol;1怎么解决

    当向EXCEL写入类似'01-01-01'或'01-01'这样的数据时,打开EXCEL时会发现数据变成了2001/1/1和1月1日. 这是由于EXCEL自动转换功能,我们得要在输入前多加一个’号. 而 ...

  3. 【leetcode】Longest Palindromic Substring &lpar;middle&rpar; 经典

    Given a string S, find the longest palindromic substring in S. You may assume that the maximum lengt ...

  4. &lbrack;转&rsqb; 用SBT编译Spark的WordCount程序

    问题导读: 1.什么是sbt? 2.sbt项目环境如何建立? 3.如何使用sbt编译打包scala? [sbt介绍 sbt是一个代码编译工具,是scala界的mvn,可以编译scala,java等,需 ...

  5. Linux如何生成列表

    如何生成列表: 方法一:{1..100} 方法二:`seq [起始数 [步进长度]] 结束数` 1,...,100 declare -i SUM=0    integer    -x

  6. iOS 10 的一些变化

    原文链接:http://www.jianshu.com/p/9756992a35ca

  7. nowcoder300J Mex

    题目链接 题意 给出一个长度为\(n(n \le 10^5)\)序列,求其每个子序列之和所组成的集合的\(mex\) 思路 这么水的题都没想出来,感觉自己脑子瓦特了. 假设前\(i\)位可以组成区间\ ...

  8. Echarts——一个简单的嵌套饼图

      </!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title& ...

  9. KNN和Kmeans聚类有什么不同?

    这两种算法之间的根本区别是,Kmeans本质上是无监督学习而KNN是监督学习.Kmeans是聚类算法,KNN是分类(或回归)算法. Kmeans算法把一个数据集分割成簇,使得形成的簇是同构的,每个簇里 ...

  10. &lbrack;PKUSC2018&rsqb;星际穿越&lpar;倍增&rpar;

    题意:n个点的图,点i和[l[i],i)的所有点连双向边.每次询问(l,r,x)表示x到[l,r]的所有点的最短路径长度和. 首先这题显然可以线段树优化建图,但是需要比较好的常数才能通过45分,还需要 ...