acwing 质数 约数 欧拉函数

目录

  • 质数
    • 试除法定质数
    • 分解质因数
    • 筛质数
  • 约数
    • 试除法求约数
    • 乘积的约数个数
    • 最大公约数
  • 欧拉函数
  • 筛法求欧拉函数和

质数

试除法定质数

bool is_prime(int num)
{if(num < 2)return false;for(int i = 2; i <= num / i; ++i)if(num % i == 0)return false;return true;
}

分解质因数

	// 一个数最小的因数就是质因数int n, num;cin >> n;for(int j = 0; j < n; ++j){cin >> num;for(int i = 2; i <= num / i; ++i){if(num % i == 0){int cnt = 0;while(num % i == 0){num /= i;cnt++;}cout << i << " " << cnt << endl;}}if(num  > 1)cout << num << " " << 1 << endl;cout << endl;}

筛质数

void get_prime()
{for(int i = 2; i <= n; ++i){if(visited[i] == false)primes[idx++] = i;  // 埃式筛法for(int j = i + i; j <= n; j += i)visited[j] = true;}
}

约数

试除法求约数


int main()
{cin >> n;for(int i = 0; i < n; ++i){cin >> num;vector<int> ret;            // 包含1和num本身for(int j = 1; j <= num / j; ++j){if(num % j == 0){ret.push_back(j);   // 这里可同时获得两个约数if(j != num / j)ret.push_back(num / j);}}sort(ret.begin(), ret.end());for(auto a : ret)cout << a << " ";cout << endl;}return 0;
}

乘积的约数个数

const int mod = 1e9 + 7;
int main()
{cin >> n;for(int i = 0; i < n; ++i){cin >> num;for(int j = 2; j <= num / j; ++j){               // 试除法求质因数及其指数while(num % j == 0){num /= j;all[j]++;}}if(num != 1)    // num本身是一个大的质因数all[num]++;}long long ret = 1;for(auto &a : all)  // 乘积总约数个数:质因数指数+1的乘积ret = ret * (a.second + 1) % mod;cout << ret;return 0;
}

最大公约数

int gcd(int a, int b)
{return b ? gcd(b, a % b) : a;
}

欧拉函数

在这里插入图片描述


int main()
{int n;cin >> n;while(n--){int num;cin >> num;int ret = num;for(int i = 2; i <= num / i; ++i){if(num % i == 0){               // 注意运算顺序ret = ret / i * (i - 1) ;while(num % i == 0)num /= i;}}if(num > 1)ret = ret / num * (num - 1) ;cout << ret << endl;}return 0;
}

筛法求欧拉函数和

void get_phi(int n)
{phi[1] = 1;for(int i = 2; i <= n; ++i){if(visited[i] == false){primes[idx++] = i;              // 获取质数phi[i] = i - 1;                 // 质数的欧拉函数}for(int j = 0; primes[j] <= n / i; ++j){visited[primes[j] * i] = true;  // 标记非质数if(i % primes[j] == 0){                               // p[j]为i的质因数phi[primes[j] * i] = phi[i] * primes[j];break;}else                            // p[j]不为i的质因数,要另乘一个p[j]质因数项phi[primes[j] * i] = phi[i] * primes[j] / primes[j] * (primes[j] - 1);}}
}

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

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

相关文章

Javaweb之SpringBootWeb案例之阿里云OSS服务集成的详细解析

2.3.3 集成 阿里云oss对象存储服务的准备工作以及入门程序我们都已经完成了&#xff0c;接下来我们就需要在案例当中集成oss对象存储服务&#xff0c;来存储和管理案例中上传的图片。 在新增员工的时候&#xff0c;上传员工的图像&#xff0c;而之所以需要上传员工的图像&…

<蓝桥杯软件赛>零基础备赛20周--第18周--动态规划初步

报名明年4月蓝桥杯软件赛的同学们&#xff0c;如果你是大一零基础&#xff0c;目前懵懂中&#xff0c;不知该怎么办&#xff0c;可以看看本博客系列&#xff1a;备赛20周合集 20周的完整安排请点击&#xff1a;20周计划 每周发1个博客&#xff0c;共20周。 在QQ群上交流答疑&am…

ASP.NET 7 Core Web 读取appsetting.json

把一些配置信息保存在json文件可以避免更改时要重新发布程序的烦恼。 我这里使用的是写一个类文件&#xff0c;然后通过program.cs启动的方式&#xff08;.net 6 开始没有startup了&#xff09;。 项目类型&#xff1a;ASP.NET Core Web MVC / .NET 7.0 / VS2022 第一步…

基于机器学习的地震预测(Earthquake Prediction with Machine Learning)

基于机器学习的地震预测&#xff08;Earthquake Prediction with Machine Learning&#xff09; 一、地震是什么二、数据组三、使用的工具和库四、预测要求五、机器学习进行地震检测的步骤六、总结 一、地震是什么 地震几乎是每个人都听说过或经历过的事情。地震基本上是一种自…

锂电池基本知识与设计

应用&#xff1a;笔记本电脑、智能手机等设备。 优点&#xff1a;较高能量密度和较长使用寿命&#xff0c;放电率低&#xff0c;可进一步延长充电间隔时间。 缺点&#xff1a;过度充电或者放电会产生不可逆的损伤&#xff0c;性能降低。高温环境下容易爆炸或者着火。 &#x…

el-tree基础的树形节点设置节点不能选中高亮出来,对已经选中的节点设置disabled,对当前节点刚选中后设置禁用disabled

一、 el-tree基础的树形节点设置节点不能选中高亮出来 需求 我们使用element-ui或者element-plus的时候会遇到树形控件的使用&#xff0c;我们使用树形控件会限制有的节点不让选中和高亮出来&#xff0c;这个时候需要我们做限制。在实现中我们发现了element-ui和element-plus…

WSL2+ubuntu 18+VsCode 配置C/C++开发环境 踩坑

1. 管理员模式打开cmd&#xff0c;或PowerShell &#xff0c;输入 wsl --install 可能出现的错误&#xff1a;无法解析服务器名称或地址 解决方式&#xff1a;科学上网 安装WSL时遇到“无法解析服务器名称或地址”的错误及解决方法 - 知乎 错误2&#xff1a;Error 0x8037…

CAD-autolisp——目录

目录页 写在前面&#xff1a;如果仅是想制作小工具&#xff0c;工具集这种&#xff0c;优先学习autolisp&#xff0c;如果想制作3d3s这种大型项目&#xff0c;或者包含大量计算&#xff0c;数据接力&#xff0c;网络通讯等功能&#xff0c;优先学习arx传送门 CAD-autolisp&…

Python tkinter (6) Listbox

Python的标准Tk GUI工具包的接口 tkinter系列文章 python tkinter窗口简单实现 Python tkinter (1) —— Label标签 Python tkinter (2) —— Button标签 Python tkinter (3) —— Entry标签 Python tkinter (4) —— Text控件 GUI 目录 Listbox 创建listbox 添加元素…

TPCC-MySQL

简介 TPC-C是专门针对联机交易处理系统&#xff08;OLTP系统&#xff09;的规范&#xff0c;一般情况下我们也把这类系统称为业务处理系统。 Tpcc-mysql是percona基于TPC-C(下面简写成TPCC)衍生出来的产品&#xff0c;专用于MySQL基准测试。其源码放在launchpad上&#xff0c…

Python语言入门到精通之练习实例2:企业发放的奖金根据利润提成的问题

题目&#xff1a;企业发放的奖金根据利润提成。利润(I)低于或等于10万元时&#xff0c;奖金可提10%&#xff1b;利润高于10万元&#xff0c;低于20万元时&#xff0c;低于10万元的部分按10%提成&#xff0c;高于10万元的部分&#xff0c;可提成7.5%&#xff1b;20万到40万之间时…

style-components如何结合bootstrap样式

styled-components 是一个用于 React&#xff08;以及其他框架的变体版本&#xff09;的 CSS-in-JS 库&#xff0c;它允许你编写可复用、动态的样式&#xff0c;并直接在组件中定义它们。Bootstrap 是一个流行的前端 UI 框架&#xff0c;提供了预设的 CSS 样式和响应式的布局。…

C/C++ protobuf与json互转

测试环境 ubuntu16.04 64bitprotocbuf&#xff1a;3.9.1 &#xff08;支持json转换需>3.0.0&#xff09; 协议 syntax "proto2";message Person{optional string name 1;optional uint32 age 2;optional string address 3; }测试代码 //protobuf > 3.0.0#…

力扣0091——解码方法

解码方法 难度&#xff1a;中等 题目描述 一条包含字母 A-Z 的消息通过以下映射进行了 编码 &#xff1a; ‘A’ -> “1” ‘B’ -> “2” … ‘Z’ -> “26” 要 解码 已编码的消息&#xff0c;所有数字必须基于上述映射的方法&#xff0c;反向映射回字母&#…

sql 行转列 日周月 图表统计

目录 目录 需求 准备 月 分析 按月分组 行转列 错误版本 正确版本 日 分析 行转列 周 分析 按周分组 行转列 本年 需求 页面有三个按钮 日周月&#xff0c;统计一周中每天(日)&#xff0c;一月中每周(周)&#xff0c;一年中每月(月)&#xff0c;设备台数 点…

常用的gpt-4 prompt words收集8

本文介绍我最近收集的一些好用的chatgpt-4的prompts&#xff0c;如果你也有好用的提示词可以互相交流一下。 1. I ran into some trouble on my way to work. 迟到原因 2. In my heart, the most delicious coffee is the Hawaii Dirty from Manner. Only the Nong series a…

新概念英语第二册(42)下

【Key structures】 “have 名词”代替普通动词 “have 名词”代替普通动词表示“完成该动作”&#xff1a;have a bathbathe &#xff1b;have a swimswim&#xff1b;have a walkwalk&#xff1b;have a looklook&#xff1b;have a restrest&#xff1b;have a smell…

8-小程序数据promise化、共享、分包

小程序API Promise化 wx.requet 官网入口 默认情况下&#xff0c;小程序官方异步API都是基于回调函数实现的 wx.request({method: , url: , data: {},header: {content-type: application/json // 默认值},success (res) {console.log(res.data)},fail () {},complete () { }…

Maven命令运行单元测试

使用idea开发多模块项目时,有时别的模块编译不通过会导致不能运行单元测试,这是我们可以使用maven命令来运行单元测试 格式 mvn -DtestDingTalkTest#getAllUsers 命令说明 mvn -Dtest 固定格式 DingTalkTest 单元测试类名 getAllUsers 单元测试方法 单元测试类和单元测试方法…

洛谷 P1098 [NOIP2007 提高组] 字符串的展开

题目链接 分析 这题分为几个函数实现&#xff1a;判断是否展开、输出 m m m 次某个字符、循环展开。 坑点 有可能会有几个 - 号连续出现。转换大小写时&#xff0c;必须先判断其是否为大小写&#xff0c;如果不是才转换。- 号两端如果相等也不行。 代码 #include <bi…