欧拉函数(Euler_Function)
一、基本概述
在数论,对正整数n,欧拉函数varphi(n)是少于或等于n的数中与n互质的数的数目。此函数以其首名研究者欧拉命名,它又称为Euler's totient function、φ函数、欧拉商数等。
二、计算公式
三、基本性质
欧拉函数用希腊字母φ表示,φ(N)表示N的欧拉函数.
对φ(N)的值,我们可以通俗地理解为小于N且与N互质的数的个数(包含1).
欧拉函数的一些性质:
1.对于素数p, φ(p)=p-1,对于对两个素数p,q φ(pq)=pq-1
欧拉函数是积性函数,但不是完全积性函数.
证明:
函数的积性即:若m,n互质,则φ(mn)=φ(m)φ(n).由“m,n互质”可知m,n无公因数,所以φ(m)φ(n)=m(1-1/p1)(1-1/p2)(1-1/p3)…(1-1/pn)·n(1-1/p1')(1-1/p2')(1-1/p3')…(1-1/pn'),其中p1,p2,p3...pn为m的质因数,p1',p2',p3'...pn'为n的质因数,而m,n无公因数,所以p1,p2,p3...pn,p1',p2',p3'...pn'互不相同,所以p1,p2,p3...pn,p1',p2',p3'...pn'均为mn的质因数且为mn质因数的全集,所以φ(mn)=mn(1-1/p1)(1-1/p2)(1-1/p3)…(1-1/pn)(1-1/p1')(1-1/p2')(1-1/p3')…(1-1/pn'),所以φ(mn)=φ(m)φ(n).
即φ(mn)=φ(n)*φ(m)只在(n,m)=1时成立.
2.对于一个正整数N的素数幂分解N=P1^q1*P2^q2*...*Pn^qn.
φ(N)=N*(1-1/P1)*(1-1/P2)*...*(1-1/Pn).
3.除了N=2,φ(N)都是偶数.
4.设N为正整数,∑φ(d)=N (d|N).
四、求欧拉函数
1、埃拉托斯特尼筛求欧拉函数
观察欧拉函数的公式, 。我们用phi[x]表示φ(x)。可以一开始把phi[x]赋值为x,然后每次找到它的质因数就(先除再乘,避免溢出)。当然,若只要求一个数的欧拉函数,可以从1到sqrt(n)扫一遍,若gcd(i,n)=1就更新phi[n] phi[n]phi[n]。复杂度为O(logn)(代码就不给了)。那要求1~n所有数的欧拉函数呢?可以用埃拉托斯特尼筛的思想,每次找到一个质数,就把它的倍数更新掉。这个复杂度虽然不是O(n),但还是挺快的(据说是O(n*ln ln n),关于证明,可以点这里,虽然我看不懂)。
代码如下:
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的倍数更新掉}}}
}
2、欧拉筛求欧拉函数
前提是要懂欧拉筛。每个数被最小的因子筛掉的同时,再进行判断。i表示当前做到的这个数,prime[j]表示当前做到的质数,那要被筛掉的合数就是i*prime[j]。若prime[j]在这个合数里只出现一次(i%prime[j]!=0),也就是i和prime[j]互质时,则根据欧拉函数的积性函数的性质,phi[i * prime[j]]=phi[i] * phi[prime[j]]。若prime[j]在这个合数里出现了不止一次(i%prime[j]=0),也就是这个合数的所有质因子都在i里出现过,那么根据公式,复杂度为O(n)。
还是看代码吧:
void euler(int n)
{phi[1]=1;//1要特判 for (int i=2;i<=n;i++){if (flag[i]==0)//这代表i是质数 {prime[++num]=i;phi[i]=i-1;}for (int j=1;j<=num&&prime[j]*i<=n;j++)//经典的欧拉筛写法 {flag[i*prime[j]]=1;//先把这个合数标记掉 if (i%prime[j]==0){phi[i*prime[j]]=phi[i]*prime[j];//若prime[j]是i的质因子,则根据计算公式,i已经包括i*prime[j]的所有质因子 break;//经典欧拉筛的核心语句,这样能保证每个数只会被自己最小的因子筛掉一次 }else phi[i*prime[j]]=phi[i]*phi[prime[j]];//利用了欧拉函数是个积性函数的性质 }}
}
五、例题
http://acm.hdu.edu.cn/showproblem.php?pid=2588
http://poj.org/problem?id=2480
http://acm.hdu.edu.cn/showproblem.php?pid=3501
https://www.luogu.org/problemnew/show/P2158
欧拉函数(Euler_Function)相关推荐
- 算法 {欧拉函数,欧拉定理,费马小定理}
欧拉函数 定义 ϕ ( x ) , x ∈ N + \phi(x), \ \ x \in N^+ ϕ(x), x∈N+ means the number of y ∈ N + y \in N^+ y ...
- poj2154-color-polyan次二面体+欧拉函数优化
N<=1e9,O(nlogn)的做法会超时.从枚举置换转变为枚举轮换长度,然后可以利用欧拉函数,把复杂度变为O(√n * logn) 1 /*-------------------------- ...
- hdu 1286( 欧拉函数 )
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1286 数学题真的是有点吃不消了... View Code 1 #include<iostream ...
- 费马定理中值定理_数论-欧拉函数、欧拉定理
欧拉函数 积性函数 满足 ( 互质) 定义 对于正整数 ,欧拉函数是小于等于 的所有数中与 互质的数的 个数. 欧拉函数是积性函数(这个证明不是很显然,这个链接里面有很多种证明方法) 记作: 公式 , ...
- poj2154(Polya+欧拉函数优化模版)
#include <cstdio> #include <cstring> #include<iostream> using namespace std; const ...
- 【数学专题】约数个数与欧拉函数
整理的算法模板合集: ACM模板 目录 一.约数个数 1. AcWing 1291. 轻拍牛头 2. AcWing 1294. 樱花 2.1 AcWing 197. 阶乘分解 3. AcWing 19 ...
- 【数学知识】三种方法求 [1,n] 中所有数欧拉函数(线性筛欧拉函数优化至 O(n) )
整理的算法模板合集: ACM模板 ①直接求小于或等于n,且与n互质的数个数(求[1,n]中所有数的欧拉函数时间复杂度:O(nn)O(n\sqrt{n})O(nn)) ②求[1,n]之间每个数的质因数 ...
- bzoj 1409 Password 矩阵快速幂+欧拉函数
可以发现,该数组的mi就是斐波那契数列 所以要矩阵快速幂搞出第n位 但是斐波那契数列上涨的很快,这就需要欧拉定理了 p^phi(q)%q=1(gcd(p,q)==1) p是素数,所以可以用 然后需要5 ...
- hdu1695(莫比乌斯)或欧拉函数+容斥
题意:求1-b和1-d之内各选一个数组成数对.问最大公约数为k的数对有多少个,数对是有序的.(b,d,k<=100000) 解法1: 这个能够简化成1-b/k 和1-d/k 的互质有序数对的个数 ...
最新文章
- 还在为学习Python没有路线发愁吗?
- 手机中陀螺仪传感器的四大作用
- 【小白学PyTorch】 2.浅谈训练集验证集和测试集
- Delphi 按Esc快捷键退出程序的简单方法
- 【最详细】数据结构(C语言版 第2版)第八章课后习题答案 严蔚敏 等 编著
- python解析apk文件_Python获取apk文件URL地址实例
- MySQL 高级 —— 复合索引简介(多列索引)
- OSChina 周一乱弹 ——节后突然不想上班的节奏
- AI产品,如何做好从零到一
- 向.NET Core项目添加EntityFrameworkCore支持
- 11.消息摘要算法之MD5
- 程序人生之二 IoC—如何才能快乐
- android studio for android learning (二十四 )bitmap and bitmapFactory
- 巴菲特致股东的一封信:1996年
- php接口统计,EKL PHP 调取_search接口查询登录统计
- 苹果手机永久删除的照片怎么恢复?
- 新买苹果电脑,mac系统中小白应该了解哪些东西?
- 腾讯X5 浏览器内核加载
- 11 计算机组成原理第七章 输入/输出系统 I/O系统基本概念 外部设备
- Integer装箱拆箱、参数传递
热门文章
- js特效 在服务器显示变形,使一行文字变形产生弯曲弧度特效的jQuery插件 - Arctext.js...
- 华硕无线路由打印机服务器,享受DIY的快乐 篇四:当普通打印机遇上智能路由器——网络打印机配置教程(以华硕AC66U B1为例)...
- 大学计算机基础 课程的说课,大学计算机基础资料说课稿.ppt
- 什么是rip协议其优缺点_RIP协议详解
- 绝地求生12月18日服务器信息,绝地求生12月18号几点更新维护完 2019绝地求生12月18日更新维护开服时间...
- matlab冲击噪声,如何用MATLAB生成噪声和冲击混合信号
- Android 从一个Activity跳转到另一个Activity获取第二个Activity的返回值
- 四十三、Linux磁盘管理和Shell编程
- 四十、SPSS数据汇总,图表制作,频率分析和描述分析
- 八十、 Springboot整合异步任务和定时任务