UVA11426 GCD - Extreme (II)---欧拉函数的运用

GCD - Extreme (II)

Given the value of N, you will have to find the value of G. The definition of G is given below:
在这里插入图片描述
Here GCD(i, j) means the greatest common divisor of integer i and integer j.
For those who have trouble understanding summation notation, the meaning of G is given in the
following code:
G=0;
for(i=1;i<N;i++)
for(j=i+1;j<=N;j++)
{
G+=gcd(i,j);
}
/Here gcd() is a function that finds
the greatest common divisor of the two
input numbers
/
Input
The input file contains at most 100 lines of inputs. Each line contains an integer N (1 < N < 4000001).
The meaning of N is given in the problem statement. Input is terminated by a line containing a single
zero.
Output
For each line of input produce one line of output. This line contains the value of G for the corresponding
N. The value of G will fit in a 64-bit signed integer.
Sample Input
10
100
200000
0
Sample Output
67
13015
143295493160

题目:
给出n,求gcd(1,2)+gcd(1,3)+gcd(2,3)+gcd(1,4)+gcd(2,4)+gcd(3,4)+…+gcd(1,n)+gcd(2,n)+…+gcd(n-1,n)
分析:
令sum(n)=gcd(1,n)+gcd(2,n)+…+gcd(n-1,n),则所求结果ans(n)=sum(2)+sum(3)+…+sum(n)
只需求出sum(n),就可以推出所有答案:ans(n)=ans(n-1)+sum(n)。
接下来重点就是求sum(n):
注意到所有gcd(x,n)都是n的约数,可以按照这个约数进行分类,用g(n,i)表示满足g(x,n)=i且x<n的正整数个数,
则sum(n)=sum { i*g(n,i)|i是n的约数 } 。注意到gcd(x,n)=i的充要条件是gcd(x/i,n/i)=1,因此满足条件的x/i有phi(n/i)个(欧拉函数),说明g(n,i)=phi(n/i)。
由于时间限制,同素数筛选法,我们需要对于每个i枚举它的倍数n并更新sum(n),这些都在预处理中完成。
代码

#include<iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
#define N 4000001
typedef long long LL;
LL a[N], b[N], dp[N];
int main()
{
    for(int i=2; i<N; i++)///欧拉打表;
    {
        if(!a[i])
        {
            for(int j=i; j<N; j+=i)
            {
                if(!a[j]) a[j]=j;
                a[j]=a[j]/i*(i-1);
            }
        }
    }
    for(int i=1; i<N; i++)///[1,n-1]中所有的数与n的gcd的和
        for(int j=i*2; j<N; j+=i)
            b[j] += a[j/i]*i;
    for(int i=2; i<N; i++)
        dp[i]=dp[i-1]+b[i];
    int n;
    while(scanf("%d", &n), n)
    {
        printf("%lld\n", dp[n]);
    }
    return 0;
}

既然说到欧拉函数,那就多写一点。
欧拉函数就是指:对于一个正整数n,小于n且和n互质的正整数(包括1)的个数,记作φ(n) 。

欧拉函数的通式:φ(n)=n * (1-1/p1) * (1-1/p2) * (1-1/p3) * (1-1/p4)……(1-1/pn), 其中p1, p2……pn为n的所有质因数,n是不为0的整数。φ(1)=1(唯一和1互质的数就是1本身)。
我们根据欧拉函数的通式,即可得到如下代码:

// 求单个数的欧拉函数
int p(int n)
{
	int ans=n;
	for(int i=2;i*i<=n;i++){
		if(n%i==0){
			ans-=ans/i; //等价于通项,把n乘进去
			while(n%i==0)//确保下一个i是n的素因数
			{
				n/=i;
			}
		}
	}
	if(n>1)ans-=ans/n; //最后可能还剩下一个素因数没有除
	return ans;
}

但是一般我们做题要求都比较多,这个时候我们要是在一个一个枚举,很大几率会超时,因此我们借鉴素数打表的思想,自然而然想起了欧拉打表

//埃拉托斯特尼筛求欧拉函数
void euler(int n)
{
    for (int i=1;i<=n;i++) phi[i]=i;
    for (int i=2;i<=n;i++)
    {
        if (phi[i]==i)//这代表i是质数
        {
            for (int j=i;j<=n;j+=i)
            {
                phi[j]=phi[j]/i*(i-1);//把i的倍数更新掉
            }
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
欧拉函数(Euler's Totient Function),也称为积性函数,是指小于等于正整数n的数中与n互质的数的个数。我们通常用φ(n)表示欧拉函数。 具体来说,如果n是一个正整数,那么φ(n)表示小于等于n的正整数中与n互质的数的个数。例如,φ(1)=1,因为1是唯一的小于等于1的正整数且1与1互质;φ(2)=1,因为小于等于2的正整数中只有1与2互质;φ(3)=2,因为小于等于3的正整数中与3互质的数是1和2。 欧拉函数的计算方法有很多,下面介绍两种常见的方法: 1. 分解质因数法 将n分解质因数,假设n的质因数分别为p1, p2, …, pk,则φ(n) = n × (1 - 1/p1) × (1 - 1/p2) × … × (1 - 1/pk)。例如,对于n=30,我们将其分解质因数得到30=2×3×5,则φ(30) = 30 × (1-1/2) × (1-1/3) × (1-1/5) = 8。 2. 筛法 我们可以使用筛法(Sieve)来计算欧拉函数。具体地,我们可以先将φ(1)至φ(n)全部初始化为其下标值,然后从2开始遍历到n,将所有能被当前遍历到的数整除的数的欧拉函数值减1即可。例如,对于n=6,我们先初始化φ(1)=1, φ(2)=2, φ(3)=3, φ(4)=4, φ(5)=5, φ(6)=6,然后从2开始遍历,将2的倍数的欧拉函数值减1,即φ(4)=φ(6)=2;然后遍历3,将3的倍数的欧拉函数值减1,即φ(6)=2。最终得到φ(1)=1, φ(2)=1, φ(3)=2, φ(4)=2, φ(5)=4, φ(6)=2。 欧拉函数在数论中有很重要的应用,例如RSA算法的安全性就基于欧拉函数的难解性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值