04 约数

定义:

若整数n除以整数d的余数为0,即d能够整除n,n是d的倍数,记作d|n.

通过质因子求一个数的约数

如果n可以表示成

n={p_1}^{c_1}{p_2}^{c_2}......{p_k}^{c_k}  其中eq?p_1%20p_2%20p_3....p_k均为n的质因子

因为对于任意一个质因子eq?p_i都有选0个 选1个 选2个....选eq?c_i个共c_i+1种可能,

n的约数个数为

f(n)=(eq?c_1+1)(eq?c_2+1)......(c_k+1)=\prod_{i=1}^{k}(c_i+1)

 

所有约数的和为:

 (p_1^0+p_1^1+p_1^2+...+p_1^{c_1})(p_2^0+p_2^1+p_2^2+...+p_2^{c_2})...(p_k^0+p_k^1+p_k^2+...+p_k^{c_k})=\prod_{i=1}^{k}(\sum_{j=0}^{c_i}p_i^{j})

#include<bits/stdc++.h>using namespace std;
const int N=1e6+10;int prime[N],idx;
bool st[N];
//线性筛求1-n的所有质数
void init(int n){for(int i=2;i<=n;i++){if(!st[i]) prime[++idx]=i;for(int j=1;prime[j]*i<=n;j++){st[prime[j]*i]=true;if(i%prime[j]==0) break;			}}
}
//nprime存所有的质数,cnt存质数的个数
int nprime[N],cnt[N],k; 
//枚举每一个质数及质数的个数求出所有的约数
void dfs(int i,int d){if(i>k){cout<<d<<" ";return;}int p=1;for(int j=0;j<=cnt[i];j++){dfs(i+1,d*p);p*=nprime[i];}
}
int main(){init(N-1);int n;cin>>n;//找到所有的质数及个数for(int i=1;prime[i]<=n;i++){int p=prime[i];if(n%p==0) nprime[++k]=p;while(n%p==0) cnt[k]++,n/=p;}int sum=1;//根据公式求解质数的个数for(int i=1;i<=k;i++){sum*=cnt[i]+1;}cout<<"约数的个数为"<<sum<<endl;long long mul=1;//根据公式求所有质数的和for(int i=1;i<=k;i++){sum=1;long long p=1;for(int j=1;j<=cnt[i];j++){p*=nprime[i];sum+=p;}mul*=sum;}cout<<"约数的和为:"<<mul<<endl;cout<<"约数分别是:";dfs(1,1);return 0;
}

通过试除法求一个数的约数

对于n的约数d≤\sqrt{n},那么n/d≥\sqrt{n}也是n的约数,n的约数都是成对出现的,有一个≥\sqrt{n}的就会有一个≤\sqrt{n}的约数,对于完全平方数n,\sqrt{n}是单独出现的,其他都是成对出现的。

因此只要扫描1~\sqrt{n}的所有数d,如果d能够整除n,那么就能找到两个约数d和n/d,时间复杂度为O(\sqrt{n})。

#include<bits/stdc++.h>using namespace std;
int n;
int factor[2000],idx;
int main(){cin>>n;for(int i=1;i<=n/i;i++){if(n%i==0){factor[++idx]=i;if(i!=n/i) factor[++idx]=n/i;}}//n的约数有idx个,约数都保存在factor中for(int i=1;i<=idx;i++) cout<<factor[i]<<" ";return 0;
}

试除法的推论: n的约数的个数上界为 2\sqrt{n}

通过倍数法求解数列的约数

对于一个1~n的序列在求解每个数的约数时,如果通过试除法复杂度O(n\sqrt{n})较高,观察到在求解每个数的约数时,都会重复枚举很多不是约数的数,如果我们只关注能够整除的约数,通过约数去找相应的数,而不是数去找约数,就会大大减少枚举的复杂度。

#include<bits/stdc++.h>using namespace std;
const int N=500010;vector<int> factor[N];int n;
int main(){cin>>n;for(int i=1;i<=n;i++){for(int j=1;j<=n/i;j++){factor[i*j].push_back(i);}}for(int i=1;i<=n;i++){cout<<i<<":";for(auto p:factor[i]){cout<<p<<" ";}cout<<endl;}return 0;
}

时间复杂度为: O(n/1+n/2+n/3+....+n/n)=O(nlogn)

使用倍数法求解区间数的约数,待验证

#include<bits/stdc++.h>using namespace std;
const int N=500010;vector<int> factor[N];int l,r;
int main(){cin>>l>>r;for(int i=1;i<=r/i;i++){int s=ceil(l*1.0/i)*i;for(int j=s;j<=r;j+=i){factor[j-l].push_back(i);factor[j-l].push_back(j/i);}}for(int i=0;i<=r-l;i++){cout<<i+l<<":";sort(factor[i].begin(),factor[i].end());for(int j=0;j<(int)factor[i].size();j++){if(j==0) cout<<factor[i][j]<<" ";else if(factor[i][j]!=factor[i][j-1]) cout<<factor[i][j]<<" ";}cout<<endl;}return 0;
}

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

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

相关文章

在DevEco开发工具中,使用Previewer预览界面中的UI组件

1、在DevEco工具中&#xff0c;点击并展开PreViewer预览器 2、在PreViewer预览器中&#xff0c;点击Tt按钮&#xff08;Inspector&#xff09;切换至组件查看模式 3、在组件查看模式下选择组件&#xff0c;代码呈现选中状态&#xff0c;右侧呈现组件树&#xff0c;右下方呈现组…

ARM 驱动 1.22

linux内核等待队列wait_queue_head_t 头文件 include <linux/wait.h> 定义并初始化 wait_queue_head_t r_wait; init_waitqueue_head(&cm_dev->r_wait); wait_queue_head_t 表示等待队列头&#xff0c;等待队列wait时&#xff0c;会导致进程或线程被休眠&…

4.调研什么样的框架可以提高ROI

一、回归本源&#xff0c;框架是为了支撑我们测试&#xff0c;所以我们对框架的要求 1.框架满足我们的测试需求 UI框架有对象识别能力API框架有http原语封装&#xff0c;对xml json支持单元测试框架有mock能力 2.框架应有广泛的同行用户、持续更新、成熟的社区和积极的客户响…

qiankun微前端部署(主/子应用部署在同一个服务)

一、部署配置 qiankun微前端改造配置就不记录了&#xff0c;只记录部署需要的配置 mypro&#xff1a;自定义的子应用名称 1. 主应用配置 &#xff08;1&#xff09;.env文件BASE_URL /MicroBase/&#xff08;2&#xff09; vue.config.js文件module.exports {publicPath: …

倍增算法笔记

主要应用场景 RMQ&#xff1a;区间最值问题 LCA&#xff1a;最近公共祖先问题 RMQ问题——区间最值 如果用数组f[N]存储,用数组a[i][j]表示从第i个数起连续 2^j 个数中的最大值,[i,i 2^j - 1],显然a[i][0] f[i],则很容易得到状态转移方程: a[i][j] max(a[i][j - 1], a[i …

读书笔记-《数据结构与算法》-摘要11[Divide and Conquer - 分治法]

在计算机科学中&#xff0c;分治法是一种很重要的算法。分治法即『分而治之』&#xff0c;把一个复杂的问题分成两个或更多的相同或相似的子问题&#xff0c;再把子问题分成更小的子问题……直到最后子问题可以简单的直接求解&#xff0c;原问题的解即子问题的解的合并。这个思…

电商API接口|爬虫案例|采集某东商品评论信息

前言&#xff1a; 平常大家都有网上购物的习惯&#xff0c;在商品下面卖的好的产品基本都会有评论&#xff0c;当然也不排除有刷评论的情况&#xff0c;因为评论会影响我们的购物决策。今天主要分享用pythonre正则表达式获取京东商品评论。API接口获取京东平台商品详情SKU数据…

11k+ star 一款不错的笔记leanote安装教程

特点 支持普通模式 支持markdown模式 支持搜索 安装教程 1.安装mongodb 1.1.下载 #下载 cd /opt wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0.1.tgz 1.2解压 tar -xvf mongodb-linux-x86_64-3.0.1.tgz 1.3配置mongodb环境变量 vim /etc/profile 增…

电脑可以连接wifi,甚至可以qq聊天,但就是不能用浏览器上网,一直显示未检测出入户网线的解决方案

今天回到家&#xff0c;准备办公却发现电脑可以连接wifi&#xff0c;甚至可以qq聊天&#xff0c;但就是不能用浏览器上网&#xff0c;一直显示未检测出入户网线的解决方案&#xff0c;小白也可以看懂 以下有几种解决方案&#xff0c;不妨都试试&#xff0c;估计可以解决95%的相…

CANoe使用大全

本专栏为入门级别保姆教程&#xff0c;主要面对CANoe使用的零基础受众。 持续更新中… &#x1f697;【CANoe使用大全】——工程新建 &#x1f697;【CANoe使用大全】——DBC数据库制作 &#x1f697;【CANoe使用大全】——Trace窗口 &#x1f697;【CANoe使用大全】——Gr…

深入理解 MySQL 中的 HAVING 关键字和聚合函数

深入理解 MySQL 中的 HAVING 关键字和聚合函数 在处理数据库查询时&#xff0c;尤其是涉及到大量数据分析和报表生成的场合&#xff0c;了解如何有效使用 SQL 语句中的 HAVING 关键字和聚合函数变得尤为重要。 什么是 HAVING 关键字&#xff1f; HAVING 关键字在 SQL 语句中…

C#-前后端分离连接mysql数据库封装接口

C#是世界上最好的语言 新建项目 如下图所示选择框红的项目 然后新建 文件夹 Common 并新建类文件 名字任意 文件内容如下 因为要连接的是mysql数据库 所以需要安装 MySql.Data.MySqlClient 依赖; using MySql.Data.MySqlClient; using System.Data;namespace WebApplication1.…

MYSQL账号和权限配置

新增用户并回收root用户的权限 flush privileges; grant all privileges on *.* to root% identified by Test2024 with grant option; grant all privileges on *.* to magic% identified by Test2024 with grant option; flush privileges; select user,host from mysql.use…

Django 为应用定制化admin独立后台

定制后界面 在应用目录下找到admin.py并进行编辑 from django.contrib.admin import AdminSite from .models import Question,Choiceclass PollsAdminSite(AdminSite):site_header"Admin-site-header"site_title"admin-site-title"index_title"admi…

优雅的控制协程(goroutine)的并发数量

对golang熟悉的小伙伴都知道&#xff0c;在go中开启go协程是一件简单的事&#xff0c;只需要一个关键字”go“。 并且相比于线程&#xff0c;所需要的系统资源非常少。于是在程序中我们总会开启协程去并发获取数据。 例如&#xff1a; 商城首页&#xff0c;每个商品需要获取…

Conda 使用environment.yml创建一个新的Python项目

Conda系列&#xff1a; 翻译: Anaconda 与 miniconda的区别Miniconda介绍以及安装Conda python运行的包和环境管理 入门Conda python管理环境environments 一 从入门到精通Conda python管理环境environments 二 从入门到精通Conda python管理环境environments 三 从入门到精通…

Ansible自动化运维(三)Playbook 模式详解

&#x1f468;‍&#x1f393;博主简介 &#x1f3c5;云计算领域优质创作者   &#x1f3c5;华为云开发者社区专家博主   &#x1f3c5;阿里云开发者社区专家博主 &#x1f48a;交流社区&#xff1a;运维交流社区 欢迎大家的加入&#xff01; &#x1f40b; 希望大家多多支…

未来已来:OJAC诚邀您与张立赛博士解锁GPT Store的无限潜力!

亲爱的伙伴们&#xff01;本月31日晚上8:30&#xff0c;我们近屿智能OJAC的培训讲师——哈尔滨工业大学博士毕业生、前之江实验室资深研究员张立赛博士&#xff0c;将为我们带来一场深度技术更新讲座&#xff0c;深度探讨GPT Store的最新发展。 本次讲座将从GPT Store的基本概念…

Linux:shell脚本:基础使用(9)《数组》

数组就是一组数据类型相同集合 定义 数组名(元素内容…………) 如果没有元素内容就是空 arr1() # 定义了一个空数组 arr2(1 2 3 4 5 6 ) # 定义了一个元素是整形的数组 arr3("hello" "world" "你好" "世界") # 定义了一个元素为字符…

什么是互联网打工人都需要知道的API?电商API是什么?

我们生活在一个科技主导的世界。在这里&#xff0c;数据无处不在。作为许多不同产品的用户&#xff0c;我们所追寻的不再是某一个能将工作完成的最佳产品&#xff0c;而是一个不仅能有效完成工作&#xff0c;同时也与我们所使用的其他工具完美兼容的产品。因此&#xff0c;了解…