输入:8800
输出:3200
通过求与n互素的1与n之间的所有a来计算
#include <bits/stdc++.h>
using namespace std;
int gcd(int a,int b)
{
if(b==0) return a;
else return gcd(b,a%b);
}
int main()
{
int n,t;
cin>>n;
int s=0;
for(int i=1;i<=n;i++)
{
t=gcd(n,i);
if(t==1)
s++;
else
continue;
}
cout << s << endl;
return 0;
}
使用n的素因数分解计算
#include<stdio.h>
#include<math.h>
int eular(int n)
{
int res=n;
for(int i=2;i<=sqrt(n);i++)//判断n是否为质数
{
if(n%i==0)res=res/i*(i-1);//res=res*(1-1/i)先进行除法防止溢出
while(n%i==0)n/=i;
}
if(n>1)res=res/n*(n-1);
return res;
}
int main()
{
int n;
scanf("%d",&n);
printf("%d",eular(n));
return 0;
}