欧拉函数和最大公约数

分析:如果两个数的最大公约数是一个质数p,那么这两个数都除以p,得到的两个数的最大公约数一定是1.

反证法:如果得到的两个数的最大公约数不是1,那么把此时的最大公约数乘以上边的最大公约数,得到的一定比上述的最大公约数大,那么上述的最大公约数就不是最大那两个数的最大公约数,所以结论错误。即得到的两个数的最大公约数一定是1.

由于发现两个数都除以p之后,得到的数的最大公约数是1,那么我们可以想到欧拉函数,此时就可以先处理欧拉函数和欧拉函数的前缀和,然后枚举1~n的所有质数,每次求1~n/p(下取整)中与n/p(下取整)互质的个数,由于(1,2),(2,1)属于两个那么还需要乘以2,(1,1)(1,1)属于1个,最后还得减去1.

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

const int N = 1e7 + 10;

int hpi[N];
int primes[N],cnt;
bool st[N];
int n;
long long s[N];

void init()
{
    hpi[1]=1;
    
    for(int i=2;i<=n;i++)
    {
        if(!st[i]) 
        {
            primes[cnt++]=i;
            hpi[i]=i-1;
        }
        
        for(int j=0;primes[j]<=n/i;j++)
        {
            st[primes[j]*i]=true;
            if(i%primes[j]==0)
            {
                hpi[primes[j]*i]=primes[j]*hpi[i];
                break;
            }
            hpi[i*primes[j]]=hpi[i]*(primes[j]-1);
        }
    }
    
    for(int i=1;i<=n;i++) s[i]=s[i-1]+hpi[i];
}
int main()
{
    cin>>n;
    
    init();
    long long res=0;
    for(int i=0;i<cnt;i++)
    {
        int p=primes[i];
        res+=(2*s[n/p]-1);
    }
    cout<<res<<endl;
    return 0;
}
相关推荐
wearegogog1231 小时前
基于 MATLAB 的卡尔曼滤波器实现,用于消除噪声并估算信号
前端·算法·matlab
一只小小汤圆1 小时前
几何算法库
算法
Evand J1 小时前
【2026课题推荐】DOA定位——MUSIC算法进行多传感器协同目标定位。附MATLAB例程运行结果
开发语言·算法·matlab
leo__5202 小时前
基于MATLAB的交互式多模型跟踪算法(IMM)实现
人工智能·算法·matlab
忆锦紫2 小时前
图像增强算法:Gamma映射算法及MATLAB实现
开发语言·算法·matlab
t198751282 小时前
基于自适应Chirplet变换的雷达回波微多普勒特征提取
算法
guygg882 小时前
采用PSO算法优化PID参数,通过调用Simulink和PSO使得ITAE标准最小化
算法
老鼠只爱大米2 小时前
LeetCode算法题详解 239:滑动窗口最大值
算法·leetcode·双端队列·滑动窗口·滑动窗口最大值·单调队列
mit6.8243 小时前
序列化|质数筛|tips|回文dp
算法
rgeshfgreh3 小时前
C++字符串处理:STL string终极指南
java·jvm·算法