欧拉函数 \(\varphi(n)\) 定义为小于 \(n\) 与 \(n\) 互质的数字,炒个例子,\(\varphi(10) = 4\),因为 \(1,3,7,9\) 与 \(10\) 互质。

怎么求?\(n\) 唯一分解成 \(p_1^{c_1}p_2^{c_2}\dots p_k^{c_k}\),则 \(\varphi(n) = n\prod\limits_{i = 1}^k \dfrac{p_i - 1}{p_i}\),证明可以用容斥做(懒得写了┓( ´∀` )┏)

它显然可以用分解质因数求单个的,也可以用埃筛求多个的,长这样

void getphi() {
for(int p = 1; p <= MAXN; p++) phi[p] = p;
for(int p = 2; p <= MAXN; p++)
if(phi[p] == p)
for(int i = p; i <= MAXN; i += p)
phi[i] = phi[i] / p * (p - 1);
}

原因显而易见。

最重要的是几条性质(也就是说我水了一半是吧 QAQ)

  1. 与 \(n\) 互质的数之和为 \(\dfrac{\varphi(n)n}{2}\)。

    这是因为 \(\gcd(n - x, n) = \gcd(n, x)\),则如果 \(x\) 与 \(n\) 互质,那么 \(n - x\) 亦与 \(n\) 互质,成对出现,和为 \(n\),有 \(\dfrac{\varphi(n)}{2}\),总和为 \(\dfrac{\varphi(n)n}{2}\)。

  2. 欧拉函数是积性函数,即 \(\varphi(ab) = \varphi(a)\varphi(b),\gcd(a, b) = 1\)

    显而易见,分解质因数即可证明。

  3. 若 \(p\) 为质数,且 \(p|n, p^2|n\),则有 \(\varphi(n) = \varphi(n/p) \times p\)。

    由于 \(p|n, p^2|n\),因此 \(n/p\) 与 \(n\) 有同样的质因子,\(\varphi(n)\) 与 \(\varphi(n/p)\) 用公式写一下显然成立(

  4. 若 \(p\) 为质数,且 \(p|n, p^2\not | n\),则有 \(\varphi(n) = \varphi(n/p) \times (p - 1)\)。

    由于 \(p|n, p^2\not|n\),则 \(n/p\) 没有质因子 \(p\),即 \(\gcd(n/p, p) = 1\),由于这是积性函数则 \(\varphi(n) = \varphi(n / p)\times \varphi(p) = \varphi(n/ p) \times (p - 1)\)。

运用 3 4 可以用欧拉筛筛这个 qwq

  1. \(\sum\limits_{d|n}\varphi(d) = n\)

欧拉。。欧拉反演。。。?

不会证明,懒得去学,跑路,有时间填坑 qAq


欧拉筛怎么筛这个(欧拉超级加倍 2333333)

欧拉筛的核心在于将一个合数拆成 \(p\times k\),其中 \(p\) 是这个数字的最小质因数。如果 \(p\) 与 \(k\) 互质,则有 \(\varphi(pk) = \varphi(p)\times (k - 1)\),否则 \(varphi(pk) = \varphi(p/k)\times p\)。原因是因为上面的 3 4 两条性质 QWQ

代码不放了,都讲到这个份上了就都会了~(主要是暂时找不到懒得写了┓( ´∀` )┏(懒狗。。。))


式子的话,一般是求和,然后我们每次是枚举 \(\gcd\),最后一波乱搞搞成欧拉函数的形式 qwq

因题而异,不写了 qwq

欧拉函数和遗忘自动机 SX 的故逝的更多相关文章

  1. 【bzoj2401】陶陶的难题I “高精度”+欧拉函数+线性筛

    题目描述 求 输入 第一行包含一个正整数T,表示有T组测试数据.接下来T<=10^5行,每行给出一个正整数N,N<=10^6. 输出 包含T行,依次给出对应的答案. 样例输入 7 1 10 ...

  2. hdu2588 GCD (欧拉函数)

    GCD 题意:输入N,M(2<=N<=1000000000, 1<=M<=N), 设1<=X<=N,求使gcd(X,N)>=M的X的个数.  (文末有题) 知 ...

  3. BZOJ 2705: [SDOI2012]Longge的问题 [欧拉函数]

    2705: [SDOI2012]Longge的问题 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 2553  Solved: 1565[Submit][ ...

  4. BZOJ 2818: Gcd [欧拉函数 质数 线性筛]【学习笔记】

    2818: Gcd Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 4436  Solved: 1957[Submit][Status][Discuss ...

  5. COGS2531. [HZOI 2016]函数的美 打表+欧拉函数

    题目:http://cogs.pw/cogs/problem/problem.php?pid=2533 这道题考察打表观察规律. 发现对f的定义实际是递归式的 f(n,k) = f(0,f(n-1,k ...

  6. poj2478 Farey Sequence (欧拉函数)

    Farey Sequence 题意:给定一个数n,求在[1,n]这个范围内两两互质的数的个数.(转化为给定一个数n,比n小且与n互质的数的个数) 知识点: 欧拉函数: 普通求法: int Euler( ...

  7. 51Nod-1136 欧拉函数

    51Nod: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1136 1136 欧拉函数 基准时间限制:1 秒 空间限制: ...

  8. 欧拉函数 - HDU1286

    欧拉函数的作用: 有[1,2.....n]这样一个集合,f(n)=这个集合中与n互质的元素的个数.欧拉函数描述了一些列与这个f(n)有关的一些性质,如下: 1.令p为一个素数,n = p ^ k,则 ...

  9. FZU 1759 欧拉函数 降幂公式

    Description   Given A,B,C, You should quickly calculate the result of A^B mod C. (1<=A,C<=1000 ...

  10. hdu 3307 Description has only two Sentences (欧拉函数+快速幂)

    Description has only two SentencesTime Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/32768 K ...

随机推荐

  1. Zabbix技术分享——使用Zabbix6.0监控业务日志

    企业日常IT运维过程中,常会碰到需要监控业务日志的情况,以下将介绍如何使用Zabbix6.0监控业务日志. 应用场景描述: 企业IT运维部门使用自建zabbix平台对公司某业务系统进行了监控.近段时间 ...

  2. python字符串常用方法介绍,基于python3.10

    python字符串常用方法-目录: 1.strip().lstrip().rstrip()2.removeprefix().removesuffix()3.replace()4.split().rsp ...

  3. 【离线数仓】Day02-用户行为数据仓库:分层介绍、环境搭建(hive、tez)、LZO压缩、建表查询导入加索引、编写脚本

    一.数仓分层概念 1.为什么要分层 ODS:原始数据层 DWD层:明细数据层 DWS:服务数据层 ADS:数据应用层 2.数仓分层 3.数据集市与数据仓库概念 4.数仓命名规范 ODS层命名为odsD ...

  4. Springboot配置多Redis源

    Springboot配置多Redis源 一.背景 因项目部署了新集群,某些缓存数据需要在旧的redis上取,就必须配置多个数据源动态获取相对应的源以兼容业务. 二.配置依赖 <dependenc ...

  5. jQuery基本使用

    目录 一:jQuery查找标签 1.基本选择器 二:分组与嵌套 三:组合选择器 四:jQuery基本筛选器 五:属性选择器 1.属性标签 六:JQuery表单筛选器 1.type属性 2.表单对象属性 ...

  6. 软件开发架构、构架趋势、OSI七层协议

    目录 软件开发架构 构架总结 网络编程前戏 OSI七层协议简介 OSI七层协议值之物理连接层 OSI七层协议之数据链层 网络相关专业名词 OSI七层协议之网络层 IP协议: IP地址特征: IP地址分 ...

  7. Redis基础学习笔记

    技术分类: 1.解决功能性的问题:Java.Jsp.RDBMS.Tomcat.HTML.Linux.JDBC.SVN 2.解决扩展性的问题:Struts.Spring.SpringMVC.Hibern ...

  8. 大数据 - DWM层 业务实现

    DWM 建表,需要看 DWS 需求. DWS 来自维度(访客.商品.地区.关键词),为了出最终的指标 ADS 需求指标 DWT 为什么实时数仓没有DWT,因为它是历史的聚集,累积结果,实时数仓中不需要 ...

  9. CH579-Lwip-2.12移植

    代码可以参考以下链接:https://gitee.com/maji19971221/lwip-routine Lwip可以在以下链接下载:http://download.savannah.gnu.or ...

  10. [python] ​Python数据序列化模块pickle使用笔记

    pickle是一个Python的内置模块,用于在Python中实现对象结构序列化和反序列化.Python序列化是一个将Python对象层次结构转换为可以本地存储或者网络传输的字节流的过程,反序列化则是 ...