欧拉函数总结

在数论,对正整数n,欧拉函数是小于n的正整数中与n互质的数的数目(φ(1)=1)。此函数以其首名研究者欧拉命名(Euler's totient function),它又称为Euler's totient function、φ函数、欧拉商数等。 例如φ(8)=4,因为1,3,5,7均和8互质。 从欧拉函数引伸出来在环论方面的事实和拉格朗日定理构成了欧拉定理的证明。

常见用到欧拉函数有两种类型:

1)

每次只求一个因子,n 不是很多,但是 n 非常大的情况。

int phi(int n){ // ou la han shu
	int res = n;
	for(int i=2;i*i <= n;i++){
			res -= res / i;
		if(n%i == 0){
			while(n%i == 0){
				n /= i;
			}
		}
	}
	if(n > 1) res -= res / n;
	return res;
}

2)

求出1~n任意给定数的质因子,适用于题目中给的n比较多,但n不是很大的情况。

可以用数组存,也可以用其他容器存。

void init(){
	for(int i=0;i<maxn;i++){
		ph[i] = i;
	}
	for(int i=2;i<maxn;i++){
		if(ph[i] == i){
			for(int j=i;j<maxn;j+=i){
				ph[j] *= i-1;
				ph[j] /= i;
			}
		}
	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值