欧拉函数求法

欧拉函数求法欧拉函数是计算在1-n中n的质因数的个数;φ(x)=x*(p1-1)/p1*(p2-1)/p2*(p3-1)/p3…*(pn-1)/pn其中p1,p2,p3…是x的质因数;若x是质数:φ(x)=x-1若x是质数p的k次幂(即x=p^k):φ(x)=p^k-p^(k-1)=(p-1)p^(k-1)积性:φ(n*m)=φ(n)*φ(m)其中m、n互质。具体的证明和其他介绍就不多说了=.

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

欧拉函数是计算在1-n中n的质因数的个数;

φ(x)=x*(p1-1)/p1*(p2-1)/p2*(p3-1)/p3…*(pn-1)/pn
其中p1,p2,p3…是x的质因数;

x是质数: φ(x)=x-1
x是质数p的k次幂(即x=p^k):φ(x)=p^k-p^(k-1)=(p-1)p^(k-1)

积性
φ(n*m)=φ(n)*φ(m)
其中m、n互质。

具体的证明和其他介绍就不多说了=.=
下面开始介绍算法。

暴力求一个欧拉值
嗯,没错很暴力。
用公式:φ(x)=x*(p1-1)/p1*(p2-1)/p2*(p3-1)/p3…*(pn-1)/pn
暴力枚举质因数,不具体说了,看代码喽:

int euler(int x){
    int res=x;
    for(int i=2;i*i<=x;++i){
        if(x%i==0){
            res=res/i*(i-1);
            while(x%i==0) x/=i;
        }
    }
    if(x>1) res=res/x*(x-1);
    return res;
}

打欧拉函数表
类似于筛法~~~~
所以可以先学习一下筛法=.=

方法一:
类似于埃氏筛
初始化phi[i]=i;
循环范围内的所有数x;
如果x是质数,将x的倍数乘1-1/x;

原理:φ(x)=x*(p1-1)/p1*(p2-1)/p2*(p3-1)/p3…*(pn-1)/pn(还是它~~~)

void euler()
{
    for(int i=1;i<=n;i++)phi[i]=i;
    for(int i=2;i<=n;i++)
        if(phi[i]==i)
            for(int j=i;j<=n;j+=i)
                phi[j]=phi[j]/i*(i-1);//防爆先除后乘;
}

方法二:
类似于线性筛

遍历1-n所有数x;
如果x是质数(m[x]为处理)那么更新phi[x],p[++tot],m[x]值;

对于每一个i用它去乘质数表第j项=k,更新m[k];
原理同线性筛:每一个合数只会被他的最小质因数筛去;

如果m[i]==p[j],更新phi[k]=phi[i]*p[j]break(保证不重复筛某个数);
正确性证明:
phi[i]=i*(p1-1)/p1*(p2-1)/p2*…*(pn-1)/pn
phi[k]=k*(p1-1)/p1*(p2-1)/p2*…*(pn-1)/pn=phi[i]*p[j](k=p[j]*i)
p[j]==m[i]所以p[j]==p1,p[j]-1/p[j]已经包含在phi[i]里;

原理:
1、φ(x)=x*(p1-1)/p1*(p2-1)/p2*(p3-1)/p3…*(pn-1)/pn;
2、若x是质数: φ(x)=x-1。

上代码~:

#include<iostream>
#include<cstring>
#include<cstdio>
#define maxn 100000000
using namespace std;

int n,tot,p[maxn],m[maxn],phi[maxn];//p-->质数,m-->i的最小质因数,phi-->欧拉值 

void euler()
{
    phi[1]=1;
    tot=0;
    int k;
    for(int i=2;i<=n;++i)
    {
        if(!m[i])//i是质数 
        {
            p[tot++]=m[i]=i;//i加入质数表,更新i的最小质因数为i 
            phi[i]=i-1;//i的欧拉函数值 
        }
        for(int j=0;j<tot&&(k=p[j]*i)<=n;j++)
        {
            m[k]=p[j];//线性筛的性质,每个合数会被他的最小质因数找到 
            if(m[i]==p[j])//i的最小质因数为质数表第j项 
            {
                phi[k]=phi[i]*p[j];//phi[i]=i*(p1-1)/p1*(p2-1)/p2*...*(pn-1)/pn而p[j]==m[i]所以p[j]==p1,p[j]-1/p[j]已经包含在phi[i]里;phi[k]=k*(p1-1)/p1*(p2-1)/p2*...*(pn-1)/pn=phi[i]*p[j](k=p[j]*i) 
                break;//防止重复计算,每个i只由m[i]更新 
            }
            else phi[k]=phi[i]*(p[j]-1);
        }
    }
}

int main()
{
    n=100000000;
    euler(); 
//  for(int i=1;i<=n;i++)
//      printf("%d %d \n",i,phi[i]);
}

实测:线性筛还是会比埃氏筛快一xu点duo;
跑100000000的欧拉表,线性筛比埃氏筛快0.8-1s~

感谢spli大神教我~ –> 膜一膜spli大神

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/172057.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月22日 下午12:00
下一篇 2022年8月22日 下午12:00


相关推荐

  • 图片介质受写入保护_写入保护

    图片介质受写入保护_写入保护最近使用U盘,突然不能正常使用了,在U盘内新建文件夹,提示“介质受写入保护”无法创建文件,赶紧网上查找解决办法。查找的结果比解释比较全面的就是:方法一:格式化我的电脑(右击)-管理-磁盘管理-选中U盘右键删除后格式化(网上的方法,这招肯定能用,但是适用于没有重要数据的前提下,格式化后之前的数据会全部丢失)方法二:修改注册表1、打开注册表win+R(即开始-运行)键入regedit.exe2、进入如…

    2025年7月16日
    8
  • C语言malloc函数的功能及用法

    C语言malloc函数的功能及用法关于C语言malloc函数函数介绍应用举例1应用举例2函数介绍malloc(memoryallocation) 中文名称:动态内存分配用于申请一块连续的指定大小的内存块区域以void*类型返回分配的内存区域地址,当无法知道内存具体位置的时候,想要绑定真正的内存空间,就需要用到动态的分配内存。应用举例1关于C语言动态申请数组(整形数据类型)空间的应用#include&amp;lt;stdio…

    2022年6月9日
    45
  • 细粒度图像分析_图像分类研究现状

    细粒度图像分析_图像分类研究现状一、概述什么是细粒度图像分类细粒度图像分类问题是对大类下的子类进行识别。细粒度图像分析任务相对通用图像(General/GenericImages)任务的区别和难点在于其图像所属类别的粒度更为精细。以图1为例,通用图像分类其任务诉求是将“袋鼠”和“狗”这两个物体大类(蓝色框和红色框中物体)分开,可见无论从样貌、形态等方面,二者还是很容易被区分的;而细粒度图像的分类任务则要求对“狗”该类类别……

    2022年10月4日
    5
  • Ubuntu 安装企业版微信

    Ubuntu 安装企业版微信下面就直接讲讲在 ubuntu 环境下如何安装企业版微信 第一步 gitclonehttp gitee com wszqkzqk deepin wine for ubuntu git 第二步 cd 到 deepin wine for ubuntu 文件夹下面 执行下列命令 install sh 第三步 在 home 目录下新建一个文件夹 我命名的是 softwares 然后 cd 进入 softwares 执行如下命令 wgethttp mirrors aliyun com

    2025年10月7日
    9
  • IIS PHP 项目 显示PHP版本过低,请升级

    IIS PHP 项目 显示PHP版本过低,请升级前言 一般表示项目没有问题可以加载 但是得下载更高级的 php 版本步骤 1 找到 PHP 的位置 2 下载更高级的 PHP 版本 放入指定文件夹 3 选择使用更高级的 PHP 文件就可以了

    2026年3月26日
    4
  • Scripting.FileSystemObject控件的用法「建议收藏」

    Scripting.FileSystemObject控件的用法「建议收藏」文件系统对象FSO的英文全称是FileSystemObject,这种对象模型提出了有别于传统的文件操作语句处理文件和文件夹的方法。通过采用object.method这种在面向对象编程中广泛使用的语法,将一系列操作文件和文件夹的动作通过调用对象本身的属性直接实现。在jsp中,Scripting.FileSystemObject控件调用可以直接在js中使用这个控件varf

    2022年7月14日
    17

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号