【数论】约数

news2025/7/12 9:31:17

文章目录

    • 一、试除法求n的所有约数
    • 二、约数个数
    • 三、约数之和
    • 四、最大公约数(欧几里得算法/辗转相除法)

一、试除法求n的所有约数

vector<int> getDivisors(int n) {
	vector<int> ans;
	for (int i = 2; i <= n / i; i++) {
		if (n % i == 0) {
			ans.push_back(i);
			if (i != n / i) {
				ans.push_back(n / i); // n == n/i,只需要存一个
			}
		}
	}
	return ans;
}

时间复杂度: O ( n ) O(\sqrt n) O(n )

二、约数个数

约数和质因子并不是一个意思,但每个约数可以表示成质因子的乘积

算数基本定理: n = p 1 c 1 ∗ p 2 c 2 ∗ . . . ∗ p k c k n=p_1^{c_1}*p_2^{c_2}*...*p_k^{c_k} n=p1c1p2c2...pkck的约数个数为: ( c 1 + 1 ) ( c 2 + 1 ) … ( c k + 1 ) (c_1+1)(c_2+1)…(c_k+1) (c1+1)(c2+1)(ck+1) p k p_k pk为质因子

例子: 12 = 2 2 × 3 1 12=2^2×3^1 12=22×31,12的约数有1,2,3,4,6,12共6个,根据公式计算同样是 ( 2 + 1 ) × ( 1 + 1 ) = 6 (2+1)×(1+1)=6 (2+1)×(1+1)=6

n的每个约数m都可以表示成 m = p 1 b 1 ∗ p 2 b 2 ∗ . . . ∗ p k b k m=p_1^{b_1}*p_2^{b_2}*...*p_k^{b_k} m=p1b1p2b2...pkbk的形式, 0 < = b k < = c k 0<=b_k<=c_k 0<=bk<=ck,每个 b k b_k bk ( c k + 1 ) (c_k+1) (ck+1)种选法,于是就有 ( c 1 + 1 ) ( c 2 + 1 ) … ( c k + 1 ) (c_1+1)(c_2+1)…(c_k+1) (c1+1)(c2+1)(ck+1)个因数

我们分解质因子后,获取质因子的指数,最后套用 ( c 1 + 1 ) ( c 2 + 1 ) … ( c k + 1 ) (c_1+1)(c_2+1)…(c_k+1) (c1+1)(c2+1)(ck+1)即可

int getDivisorsNum(int n) {
	vector<int> nums;
	for (int i = 2; i <= n / i; i++) {
		if (n % i == 0) {
			int num = 0;
			while (n % i == 0) {
				n /= i;
				num++;
			}
			// 获取质因子的指数
			nums.push_back(num);
		}
	}
	if(n > 1) nums.push_back(1);
	int ans = 1;
	for (int num : nums) {
		ans *= (num + 1);
	}
	return ans;
}

三、约数之和

在这里插入图片描述

例子: 12 = 2 2 × 3 1 12=2^2×3^1 12=22×31,12的约数有1,2,3,4,6,12,约数之和为28,根据公式计算同样是 ( 2 0 + 2 1 + 2 2 ) × ( 3 0 + 3 1 ) = 28 (2^0+2^1+2^2)×(3^0+3^1)=28 (20+21+22)×(30+31)=28

其中, p 0 + p 1 + p 2 + . . . + p n = ( ( ( p + 1 ) × p + 1 ) × p + 1... ) + 1 p^0+p^1+p^2+...+p^n=(((p+1)×p+1)×p+1...)+1 p0+p1+p2+...+pn=(((p+1)×p+1)×p+1...)+1,一直循环n次

int getDivisorsSum(int n) {
	const int mod = 1e9 + 7;
	unordered_map<int, int> primes;
	for (int i = 2; i <= n / i; i++) {
		if (n % i == 0) {
			while (n % i == 0) {
				n /= i;
				primes[i]++;
			}
		}
	}
	if (n > 1) primes[n] = 1;
	
	long long ans = 1;
	for (auto prime : primes) {
		int p = prime.first;
		int n = prime.second;
		// 计算sum = p^0 + p^1 + p^2 + ... + p^n
		long long sum = 1;
		while (n >= 1) {
			sum = (sum * p + 1) % mod;
			n--;
		}
		ans = ans * sum % mod;
	}
	return ans;
}

四、最大公约数(欧几里得算法/辗转相除法)

如果d是a的约数,也是b的约数,则d是ax+by的约数,则有: g c d ( a , b ) = g c d ( b , a % b ) gcd(a,b)=gcd(b,a\%b) gcd(a,b)=gcd(b,a%b) g c d ( a , 0 ) = a gcd(a,0)=a gcd(a,0)=a

比如a=24,b=18,那么gcd(24,18)=6,gcd(18,24%18)=6

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

时间复杂度为 O ( l o g n ) O(logn) O(logn)

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

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

相关文章

深度学习Week8-咖啡豆识别(Pytorch)

目录 一、前期准备 1.设置GPU 2. 导入数据 3. 划分数据集 二、手动搭建VGG-16模型 1. 搭建模型​编辑 2. 查看模型详情 三、 训练模型 1. 编写训练函数 2. 编写测试函数 4. 正式训练 四、 结果可视化 1. Loss与Accuracy图 2. 指定图片进行预测 3. 模型评估 *五、优…

[附源码]java毕业设计中达小区物业管理系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

学生家乡网页设计作品静态HTML网页模板源码 广西旅游景点网页设计 大学生家乡主题网站制作 简单家乡介绍网页设计成品

家乡旅游景点网页作业制作 网页代码运用了DIV盒子的使用方法&#xff0c;如盒子的嵌套、浮动、margin、border、background等属性的使用&#xff0c;外部大盒子设定居中&#xff0c;内部左中右布局&#xff0c;下方横向浮动排列&#xff0c;大学学习的前端知识点和布局方式都有…

Packet Tracer - 配置 IPv4 和 IPv6 接口

地址分配表 设备 接口 IPv4 地址 子网掩码 默认网关 IPv6 地址/前缀 R1 G0/0 172.16.20.1 255.255.255.128 不适用 G0/1 172.16.20.129 255.255.255.128 不适用 S0/0/0 209.165.200.225 255.255.255.252 不适用 PC1 NIC 172.16.20.10 255.255.255.128 1…

微服务架构的环境搭建及简单测试

目录 一、系统架构的演变过程 1.0 前言 1.1 单体应用架构 1.2 垂直应用架构 1.3 分布式架构 1.4 SOA架构 1.5 微服务架构 二、微服务架构搭建 2.1 微服务架构简介 2.2 微服务案例准备 2.3 创建父工程、基础模块 2.4 创建微服务 一、系统架构的演变过程 1.0 前言 随着互联网的…

【Queue】- 从源码分析PriorityQueue及其常用方法

文章目录PriorityQueue基础知识概述PriorityQueue内部结构PriorityQueue扩容操作PriorityQueue队列的构造方法PriorityQueue队列的常用方法public boolean offer(E e)public E peek()public boolean remove(Object o)public boolean contains(Object o)public Object[] toArray…

【SU-03T离线语音模块】:学习配置使用

前言 时不可以苟遇&#xff0c;道不可以虚行。 一、介绍 1、什么是语音识别模块 语音识别模块是在一种基于嵌入式的语音识别技术的模块&#xff0c;主要包括语音识别芯片和一些其他的附属电路&#xff0c;能够方便的与主控芯片进行通讯&#xff0c;开发者可以方便的将该模块嵌…

Node.js 入门教程 3 如何安装 Node.js

Node.js 入门教程 Node.js官方入门教程 Node.js中文网 本文仅用于学习记录&#xff0c;不存在任何商业用途&#xff0c;如侵删 文章目录Node.js 入门教程3 如何安装 Node.js3 如何安装 Node.js Node.js 可以通过多种方式安装。 所有主流平台的官方软件包都可以在 http://node…

终于见识到了微服务的天花板:阿里内部SpringCloud全线手册,太强了

后台都是在问微服务架构的面试题怎么答&#xff0c;想聊聊微服务架构了。微服务架构一跃成为 IT 领域炙手可热的话题也就这两年的事&#xff0c;大量一线互联网公司因为庞大的业务体量和业务需求&#xff0c;纷纷投入了微服务架构的建设中&#xff0c;像阿里巴巴、百度、美团等…

226. 翻转二叉树

文章目录1.题目2.示例3.答案①递归②迭代1.题目 给你一棵二叉树的根节点 root &#xff0c;翻转这棵二叉树&#xff0c;并返回其根节点。 2.示例 输入&#xff1a;root [4,2,7,1,3,6,9] 输出&#xff1a;[4,7,2,9,6,3,1]输入&#xff1a;root [4,2,7,1,3,6,9] 输出&#xf…

智慧应急解决方案-最新全套文件

智慧应急解决方案-最新全套文件一、建设背景二、建设思路应急管理信息化发展“四纵四横”总体架构1、两网络2、四体系3、两机制三、建设方案四、获取 - 智慧应急全套最新解决方案合集一、建设背景 建立应急大数据管理体系是应急管理信息化建设中的重要环节&#xff0c;决定了应…

将数组沿指定轴划分为子数组numpy.split()

【小白从小学Python、C、Java】 【计算机等级考试500强双证书】 【Python-数据分析】 将数组沿指定轴划分为子数组 numpy.split() [太阳]选择题 以下python代码输出错误的一项是? import numpy as np xnp.array([1,2,3,4,5,6,7,8,9,10,11,12]) print(【显示】x&#x…

数据库安装记录——Mysql8.0.23 msi 保姆级安装教程

今天遇到现场服务器安装数据库&#xff0c;特意记录安装过程。 本篇记录的服务器系统为&#xff1a;Windows Server 2012 R2 Standard 数据库版本为&#xff1a;Mysql8.0.23 msi 1、官网下载相应版本 2、安装过程 开端不顺&#xff0c;开始就出弹窗&#xff1a; 先插入一…

下载神器-IDM使用教程及下载

软件介绍&#xff1a; IDM是“Internet Download Manager”的简称&#xff0c;意思是“互联网下载管理器”&#xff0c;既是一类软件的统称&#xff0c;也专指一个非常知名的互联网下载器&#xff0c;这个软件的名字就叫IDM&#xff0c;被誉为地表最强下载器&#xff0c;屌丝救…

Flutter 中使用 extension 使项目更具可读性和效率 01

Flutter 中使用 extension 使项目更具可读性和效率 01 原文 https://medium.com/bedirhanssaglam/make-your-flutter-projects-more-readable-and-effective-with-extensions-b7dffd32e2f4 前言 代码的可读性和实用性在《 Flutter 》中非常重要。今天我们将编写一些 extension …

代码行覆盖率学习

【强力推荐】jacoco代码测试覆盖率实战教学全集&#xff0c;7天从入门到精通【理论实战 赶紧拿走】_哔哩哔哩_bilibili on-the-fly: 测试的时候代码是动态的, 需要测试就帮你插桩, 不测就不帮你插桩 offline: 先把被测代码拿到一次性直接插桩, 一运行桩就已经插好了, 直接生成…

如何把一个视频分割成不同时长的多个小视频

大家平时找素材是不是有点困难&#xff0c;如何把一个视频一个分割成多个不同时长的小视频呢&#xff0c;分割视频时能不能按我们需要来分割&#xff0c;今天小编带大伙来了解决下分割视频操作方法和步骤。 先来看下原来视频&#xff0c;原视频时长是比较长的 接下来我们准备一…

掌握这些 Spring Boot 启动扩展点,已经超过 90% 的人了!

1.背景 Spring的核心思想就是容器&#xff0c;当容器refresh的时候&#xff0c;外部看上去风平浪静&#xff0c;其实内部则是一片惊涛骇浪&#xff0c;汪洋一片。Springboot更是封装了Spring&#xff0c;遵循约定大于配置&#xff0c;加上自动装配的机制。很多时候我们只要引用…

Docker - Docker部署war包

使用Docker部署war项目&#xff0c;必须要用容器&#xff0c;我们就用tomcact容器&#xff0c;其实都是将war包丢到tomcat的webapps目录下&#xff0c;tomcat启动的情况下会自动解压war包 部署war包有两种方式 1、在Docker中安装tomcat容器的镜像&#xff0c;然后把war包丢到…

【无人机】模拟一群配备向下摄像头的移动空中代理覆盖平面区域(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜…