poj 2478 Farey Sequence(欧拉函数是基于寻求筛法素数)

poj 2478 Farey Sequence(欧拉函数是基于寻求筛法素数)

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

http://poj.org/problem?id=2478

求欧拉函数的模板。

初涉欧拉函数,先学一学它主要的性质。

1.欧拉函数是求小于n且和n互质(包含1)的正整数的个数。

记为φ(n)。

2.欧拉定理:若a与n互质。那么有a^φ(n) ≡ 1(mod n),经经常使用于求幂的模。

3.若p是一个质数,那么φ(p) = p-1。注意φ(1) = 1。

4.欧拉函数是积性函数:

若m与n互质,那么φ(nm) = φ(n) * φ(m)。

若n = p^k且p为质数,那么φ(n) = p^k – p^(k-1) = p^(k-1) * (p-1)。

5.当n为奇数时,有φ(2*n) = φ(n)。

6.基于素数筛的求欧拉函数的重要根据:

设a是n的质因数,若(N%a == 0 && (N/a)%a == 0) 则 φ(N) = φ(N/a)*a; 若(N%a == 0 && (N/a)%a != 0) 则φ(N) = φ(N/a)*(a-1)。


该题就是基于性质六,在线性时间内求欧拉函数。

#include <stdio.h>
#include <iostream>
#include <algorithm>
#include <set>
#include <map>
#include <vector>
#include <math.h>
#include <string.h>
#include <queue>
#include <string>
#include <stdlib.h>
#define LL long long
#define _LL __int64
#define eps 1e-8
#define PI acos(-1.0)

using namespace std;
const int maxn = 1000010;
const int INF = 0x3f3f3f3f;

int n;
LL num[maxn];

LL phi[maxn]; //相应φ(i)
int flag[maxn]; //flag[i] = 0说明i是素数。否则不是素数
int prime[maxn];//存素数

void get_phi()
{
	int i,j,k;
	memset(flag,0,sizeof(flag));
	phi[1] = 1;
	k = 0;

	for(i = 2; i <= maxn; i++)
	{
		if(!flag[i]) //i是素数
		{
			phi[i] = i-1;
			prime[++k] = i;
		}
		for(j = 1; j <= k && prime[j]*i <= maxn; j++)
		{
			flag[i*prime[j]] = 1;
			if(i % prime[j] == 0)
				phi[i*prime[j]] = phi[i] * prime[j];
			else phi[i*prime[j]] = phi[i] * (prime[j]-1);
		}
	}
}

int main()
{
	get_phi();
	num[1] = 0;
	for(int i = 2; i <= maxn; i++)
		num[i] = num[i-1] + phi[i];

	while(~scanf("%d",&n)&&n)
		printf("%lld\n",num[n]);

	return 0;
}

版权声明:本文博客原创文章,博客,未经同意,不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117698.html原文链接:https://javaforall.net

(0)
上一篇 2022年1月1日 下午6:00
下一篇 2022年1月1日 下午7:00


相关推荐

  • Windows系统下配置允许Redis远程访问

    Windows系统下配置允许Redis远程访问

    2020年11月9日
    211
  • 关于C语言中fseek函数的使用

    关于C语言中fseek函数的使用关于 C 语言中

    2026年3月19日
    1
  • beta分布介绍

    beta分布介绍相信大家学过统计学的都对正态分布二项分布均匀分布等等很熟悉了 但是却鲜少有人去介绍 beta 分布的 用一句话来说 beta 分布可以看作一个概率的概率分布 当你不知道一个东西的具体概率是多少时 它可以给出了所有概率出现的可能性大小 举一个简单的例子 熟悉棒球运动的都知道有一个指标就是棒球击球率 battingavera 就是用一个运动员击中的球数除以击球的总数 我们一般认为 0 26

    2025年12月9日
    5
  • 太极图正确画法_来氏太极图的画法及六行太极图的演示

    太极图正确画法_来氏太极图的画法及六行太极图的演示本来,我已打算停中发文,但是这一篇涉及到我一个重要的思想,这就是我对明代来知德的“来氏太极图”有了重要的理解,我根据它形成了我的六行太极理论,于是我还是决定把它公布出来。我尝试很多办法把水火金木土风的六行的元素融入到太极图中,它既要能符合太极的原理,又要能符合六行的原理,但又要使用它最简单化,可始终无果,有一天,我看到了明代理学家来知德的《来瞿唐先生圆图》,忽然恍然大悟,来瞿唐先生的“来氏太极图”…

    2022年5月27日
    63
  • WEB各种环境以及注意事项「建议收藏」

    WEB各种环境以及注意事项「建议收藏」WEB各种环境以及注意事项

    2022年4月22日
    87
  • 可行性成本效益分析_经济可行性和技术可行性

    可行性成本效益分析_经济可行性和技术可行性净现值(NetPresentValue,NPV):说的是把未来期望收入的钱换算成现在的钱(跟算利息类似,不过是反向运算,例如明年你会赚110元,假设贴现率是10%,那么换算成现在的钱也就是110

    2022年8月4日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号