【算法】数论---欧拉函数

什么是欧拉函数?

对于正整数n,欧拉函数是小于或等于n的正整数中与n互质的数的数目,记作φ(n)

φ(1)=1

当m,n互质时,φ(mn)=φ(m)∗φ(n)

 


一、求一个正整数的欧拉函数---(先对它分解质因数,然后套公式)

int x; cin>>x;
int ans=x;map<int,int>h;
for(int i=2;i<=x/i;i++)
{while(x%i==0){x/=i;h[i]++;}
}
if(x>1)h[x]++;for(auto i:h)
{int j=i.first;  //因为j最大不超过2x10^9,所有j的数据类型用int就足够了ans=ans/j*(j-1);  //因为每个j都是ans的质因子,所有ans/j肯定可以整除的,并且因为ans/j*(j-1)的结果肯定会小于ans,所有ans的数据类型用int就足够了
}//这里必须得是ans/j*(j-1)这个顺序,防止爆intcout<<ans<<endl;

二、求一个正整数的欧拉函数---线性筛法

#include<iostream>
using namespace std;const int N=1000010;int primes[N],idx=0;bool st[N];int ou[N];int main()
{int n; cin>>n;for(int i=2;i<=n;i++){if(!st[i]){primes[idx++]=i;ou[i]=i-1;}for(int j=0;primes[j]*i<=n;j++){st[primes[j]*i]=true;  //primes[j]*i将会遍历所有的和数,然后在这里将它们标记(筛掉),再在下面将它们的欧拉函数求出if(i%primes[j]==0)  //i%primes[j]==0说明primes[j]是i的最小质因数{ou[primes[j]*i]=ou[i]*primes[j];break;}else  //i%primes[j]!=0说明primes[j]是比i的最小质因数还要小的质数{ou[primes[j]*i]=ou[i]*primes[j]/primes[j]*(primes[j]-1);}}}ou[1]=1;long long ans=0;for(int i=1;i<=n;i++)ans+=ou[i];cout<<ans;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/588220.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

10-1 HNCST - 多线程3 - 线程同步Lock——python

本题要求实现一个机器人Robot类&#xff0c;该类为一个线程类&#xff0c;他能够从货物列表goods中取出货物&#xff0c;并输出。现有一批货物&#xff0c;容量为size&#xff0c;工厂配备了m个机器人&#xff08;线程&#xff09;不停地进行搬运&#xff0c;直到货物搬完&…

海康visionmaster流程 ID:通过流程名获取流程 ID 的方法

环境&#xff1a;VM4.0.0vs2015 及以上 现象&#xff1a;怎么获取流程 ID&#xff1f; 解答 通过流程名可以获取流程 ID。 c# public static bool GetProcessID(string ProcessName, ref int ProcessI D, ref string ErrorMessage) { bool findIDResult false; try { ProcessI…

2024年,程序员有哪些危机,有什么应对方式?

在2024年&#xff0c;程序员可能面临的危机主要包括技术更新迅速、职业竞争激烈、工作与生活平衡困难等方面。 为了应对这些危机&#xff0c;程序员可以采取以下策略&#xff1a; 技术更新迅速&#xff1a;随着技术的不断发展&#xff0c;新的编程语言和工具不断涌现&#xff…

spring核心与思想

spring核心与思想 Spring 是什么&#xff1f;什么是容器&#xff1f;什么是 IoC&#xff1f;传统程序开发传统程序开发的缺陷解决传统开发中的缺陷控制反转式程序开发对⽐总结规律 理解 Spring IoCDI 概念说明 Spring 是什么&#xff1f; Spring 指的是 Spring Framework&…

【面试题】HTTP 协议中 URI 和 URL 的区别

URI: Uniform Resource Identifier, 统一资源标识符。用来唯一标识资源&#xff0c;是一种语义上的抽象概念。 URL: Uniform Resource Locator, 统一资源定位符。用来定位唯一的资源&#xff0c; 必须提供足够的定位信息。 1. URI和URL的区别&#xff1a; 统一资源标识符URI…

Springcloud Alibaba使用Canal将Mysql数据实时同步到Redis保证缓存的一致性

目录 1. 背景 2. Windows系统安装canal 3.Mysql准备工作 4. 公共依赖包 5. Redis缓存设计 6. mall-canal-service 1. 背景 canal [kənl] &#xff0c;译意为水道/管道/沟渠&#xff0c;主要用途是基于 MySQL 数据库增量日志解析&#xff0c;提供增量数据订阅和消费。其诞…

C语言实验5:结构体

目录 一、实验要求 二、实验原理 1. 普通结构体 1.1 显示声明结构体变量 1.2 直接声明结构体变量 ​编辑 1.3 typedef在结构体中的作用 2. 结构体的嵌套 3. 结构体数组 4. 指向结构体的指针 4.1 静态分配 4.2 动态分配 三、实验内容 1. 学生数据库 代码 截图 …

矩阵微分笔记(3)

目录 前言矩阵求导1. 矩阵的迹1.1 定义1.2 迹的性质 2. 矩阵微分的几种情况2.1 向量变元的实值标量函数2.2 矩阵变元的实值标量函数2.3 矩阵变元的实矩阵函数 3. 矩阵微分3.1 矩阵微分的意义3.2 矩阵微分示范 参考 前言 这篇笔记的内容是基于参考的文章写出的&#xff0c;公式…

HarmonyOS ARKUI深度解析:图像组件及权限配置实战指南

文章目录 深入学习RKUI中的图片组件及权限配置图片组件简介图片源的三种格式Image : 图片显示组件图片组件属性及样式控制图片权限配置文章总结问题总结深入学习RKUI中的图片组件及权限配置 在本文中,我们将深入学习ArkUI(HarmonyOS UI框架)中的图片组件及其相关属性,同时…

vue 项目 添加 页面上方 NProgress进度条

NProgress官网和Github地址 路由 跳转时 页面上方 和 右上角 会有一个加载进度 安装 使用npm安装 npm install --save nprogress 基本用法 main.js 引入 import NProgress from “nprogress”; import “nprogress/nprogress.css”; 开关和关闭 start()开启NProgress进度条d…

基于Ubuntu环境Git服务器搭建及使用

基于Ubuntu环境Git服务器搭建及使用 Chapter1 搭建本地git服务器及详细操作步骤1.搭建本地git服务器1.1 环境1.2 服务端配置1.3 创建git专属用户1.4 创建git仓库1.5 配置免密登录基础 2.客户端拉取推送代码2.1客户端创建ssh公钥 2.2 免密配置3.仓库使用&#xff08;拉取及推送代…

VCD Value Change Dump格式解析

VCD ValueChange Dump 是一种记录被选择信号在仿真过程中的变化情况的ASCII文件格式。常用的有四值格式&#xff08;数值变化0,1,x,z,不含强度信息&#xff09;&#xff0c;扩展格式&#xff08;含数值变化的所有信息&#xff09;。 以四值格式VCD为例。 $dateThu Dec 28 …

【linux】tail的基本使用

在linux可以用find查找一个文件&#xff0c;可以用grep查找符合要求的文件内容&#xff0c;但是有的时候希望查看文件的前几行或者后几行&#xff08;其实这种场景经常可以遇到&#xff0c;比如接触到日志分析的时候&#xff09;&#xff0c;那就应该使用head和tail这两个工具了…

如何使用ModuleShifting测试Module Stomping和Module Overloading注入技术

关于ModuleShifting ModuleShifting是一款针对Module Stomping和Module Overloading注入技术的安全测试工具&#xff0c;该工具基于Python ctypes实现其功能&#xff0c;因此可以通过Python解释器或Pyramid在内存中完整执行&#xff0c;这样就可以避免使用编译加载器了。 需要…

基于SpringBoot的中小型企业质量管理

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于SpringBoot的中小型企业质量管理,ja…

大语言模型(LLM)训练平台与工具

LLM 是利用深度学习和大数据训练的人工智能系统&#xff0c;专门 设计来理解、生成和回应自然语言。 大模型训练平台和工具提供了强大且灵活的基础设施&#xff0c;使得开发和训练复杂的语言模型变得可行且高效。 平台和工具提供了先进的算法、预训练模型和优化技术&#xff0c…

HarmonyOS 组件通用属性之通用事件 文档参数讲解(点击事件)

我们组件中 会有很多通用的信息和方法 那么 首先 我们看通用事件 通用事件中 最常用的就是我们的点击事件 比如说 我们之前常写的 组件.onClick(()>{//事件逻辑 })但是 我们之前 都没有用它接参数 我们可以这样 Button("跳转").onClick((ewat: ClickEvent)>…

边界判断缺失

作者简介&#xff1a;大家好&#xff0c;我是smart哥&#xff0c;前中兴通讯、美团架构师&#xff0c;现某互联网公司CTO 联系qq&#xff1a;184480602&#xff0c;加我进群&#xff0c;大家一起学习&#xff0c;一起进步&#xff0c;一起对抗互联网寒冬 学习必须往深处挖&…

2023年03月20日_对李开复3月20日线下媒体会的解读

最近这个AI大模型 因为GPT4.0 ChatGPT 文心一言等等这些事情呢 一下子就被推到了风口浪尖 我们也做了来介绍相关的进展 国内呢也不断有一些大佬开始下场 包括王慧文、张朝阳、李彦宏什么的 都开始说自己要搞AI大模型 就在昨天呢 创新工厂的董事长兼CEO李开复 也发朋友…

2024年:三大壁炉趋势

2024年的壁炉趋势是环保的、现代的和100%安全的&#xff0c;作为装饰性壁炉已经比取暖的壁炉更加受欢迎。现今&#xff0c;作为装饰性观赏的壁炉与为了加热取暖而开发的燃木壁炉、燃气壁炉之间存在明显区别。尽管加热取暖的壁炉在农村很有意义&#xff0c;但是装饰性壁炉在城市…