欧拉函数
参考资料
定义
欧拉函数(Euler's totient function),即 ,表示的是小于等于 和 互质的数的个数。
例如 ;当 是质数的时候,显然有 。
实现
ll phi(ll n)
{
ll res=n;
for(ll i=2;i*i<=n;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;
}
欧拉定理
与欧拉函数紧密相关的一个定理就是欧拉定理。其描述如下:
若 ,则 。
扩展欧拉定理
当然也有扩展欧拉定理,用于处理一般的 和 的情形。
例题
给你三个正整数 ,求 。Code (1)