欧拉函数,欧拉定理,费马小定理介绍及模板

2023-10-05 23:31

本文主要是介绍欧拉函数,欧拉定理,费马小定理介绍及模板,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

介绍

欧拉函数的定义:对于正整数 n n ,欧拉函数是小于等于n的数中,与 n n 互质的数的数目

欧拉函数又称ϕ函数,例如 ϕ(8)=4 ϕ ( 8 ) = 4 ,因为1,3,5,7均和8互质

定理:

  1. 如果 n n 为某一个素数p,则: ϕ(p)=p1 ϕ ( p ) = p − 1
  2. 如果 n n 为某一个素数p的幂次 pa p a ,则: ϕ(pa)=(p1)pa1 ϕ ( p a ) = ( p − 1 ) ∗ p a − 1
  3. 如果 n n 为任意两个互质的数a,b的乘积,则: ϕ(ab)=ϕ(a)ϕ(b) ϕ ( a ∗ b ) = ϕ ( a ) ∗ ϕ ( b )
  4. n=pa11pa22...pakk n = p 1 a 1 ∗ p 2 a 2 ∗ . . . ∗ p k a k 为正整数 n n 素数幂分解,那么
    ϕ(n)=n(11p1)(11p2)...(11pk)

    推论: 当 n n 为奇数时,有ϕ(2n)=ϕ(n)

以下是两个常用的定理:

  • 欧拉定理:对于任何两个数值的正整数 a,m a , m (m>=2),有 aϕ(m)1(mod m) a ϕ ( m ) ≡ 1 ( m o d m )
  • 费马小定理: 当 m m 是质数时,am11(mod m)

模板

返回小于等于n且与n互质的数的个数

int euler_phi(int n)  
{  int res = n;  int m = (int)sqrt(n);  for(int i = 2; i <= m; i++)  if(n % i == 0)  {  res = res / i * (i-1);  while(n % i == 0) n /= i;  }  if(n > 1) res = res / n * (n-1);  return res;  
}

筛选法求欧拉函数

void euler_phi()  
{  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) //j要从i开始,这样可以处理素数的情况  phi[j] = phi[j] / i * (i-1);  
}  

这篇关于欧拉函数,欧拉定理,费马小定理介绍及模板的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/152289

相关文章

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

Python的time模块一些常用功能(各种与时间相关的函数)

《Python的time模块一些常用功能(各种与时间相关的函数)》Python的time模块提供了各种与时间相关的函数,包括获取当前时间、处理时间间隔、执行时间测量等,:本文主要介绍Python的... 目录1. 获取当前时间2. 时间格式化3. 延时执行4. 时间戳运算5. 计算代码执行时间6. 转换为指

Python正则表达式语法及re模块中的常用函数详解

《Python正则表达式语法及re模块中的常用函数详解》这篇文章主要给大家介绍了关于Python正则表达式语法及re模块中常用函数的相关资料,正则表达式是一种强大的字符串处理工具,可以用于匹配、切分、... 目录概念、作用和步骤语法re模块中的常用函数总结 概念、作用和步骤概念: 本身也是一个字符串,其中

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

Pytest多环境切换的常见方法介绍

《Pytest多环境切换的常见方法介绍》Pytest作为自动化测试的主力框架,如何实现本地、测试、预发、生产环境的灵活切换,本文总结了通过pytest框架实现自由环境切换的几种方法,大家可以根据需要进... 目录1.pytest-base-url2.hooks函数3.yml和fixture结论你是否也遇到过

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序