数论基础A

news/2025/1/1 13:01:09/文章来源:https://www.cnblogs.com/dianman/p/18639293

数论基础A


欧几里得算法(辗转相除法)求最大公约数GCD

有两个整数 \(a,b(a>b)\) ,记它们的最大公约数为 \(gcd(a,b)\),对于任意的 \(a,b\ne 0\) 满足等式 :

\[gcd(a,b)=gcd(b,a\% b) \]

  • 充分性证明:

    \(d\)\(a,b\) 的最大公约数,那么有 \(d\mid a\)\(d\mid b\) 成立,组合出 \(d\mid (a-kb),\ (k\in N)\) 也成立,其中 \(a-kb=a\%b\)

  • 必要性证明:

    \(d\)\(a,a\% b\) 的最大公约数,那么有 \(d\mid a\)\(d\mid (a-kb),\ (k\in N)\) 成立,同样可以组合出 \(d\mid b\) 成立

程序设计中可以递归求解,递归出口为 \(a,b=0\) ,其中不为 \(0\) 的项即为最大公约数(\(a>b\)

int gcd(int a, int b){if (b == 0) return a;return gcd(b, a % b);
}
  • 复杂度分析:

    \(a\)\(b\) 的模时,至少可以将 \(a\) 缩小到 \(a/2\) ,即 \(a\% b \le a/2\) ,证明如下

    • \(b< a/2\) 时,\(a\% b<b< a/2\)
    • \(b>a/2\) 时,\(a\%b=a-b\le a/2\)
    • \(b=a/2\) 时,\(a\% b=0<a/2\) (特殊状况,\(b\)\(a\) 因子)

最小公倍数LCM

有两个整数 \(a,b(a,b\ne 0)\) ,记它们的最小公倍数为 \(lcm(a,b)\),对于任意的 \(a,b\ne 0\) 满足等式 :

\[lcm(a,b)=\frac{a\times b}{gcd(a,b)} \]

计算LCM需要先计算出GCD,采用先除后乘防止溢出

int lcm(int a, int b){return a / gcd(a, b) * b;
}

算数基本定理(整数惟一分解定理)

对于任意的一个正整数 \(n\) ,有且仅有一种由质数的乘积所表达的方式

\[n=p_1^{\alpha_1}\cdot p_2^{\alpha_2}\cdot\cdot\cdot p_s^{\alpha_s} \quad \quad p_1<p_2<\cdot \cdot\cdot<p_s \]

  • \(n\) 至多含有一个大于 \(\sqrt{n}\) 的质因子

    根据上述的表达方式可以反推,若有两个大于 \(\sqrt{n}\) 的质因子,它们的乘积一定大于了 \(n\)

  • 证明LCM表达式

    设 :

    \[a=p_1^{\alpha_1}\cdot p_2^{\alpha_2}\cdot\cdot\cdot p_s^{\alpha_s} \\ b=p_1^{\beta_1}\cdot p_2^{\beta_2}\cdot\cdot\cdot p_s^{\beta_s} \]

    那么 \(gcd(a,b)\)\(lcm(a,b)\) 可表示为

    \[gcd(a,b)=p_1^{min(\alpha_1,\beta_1)}\cdot p_2^{min(\alpha_2,\beta_2)}\cdot\cdot\cdot p_s^{\min(\alpha_s,\beta_s)} \\ lcm(a,b)=p_1^{max(\alpha_1,\beta_1)}\cdot p_2^{max(\alpha_2,\beta_2)}\cdot\cdot\cdot p_s^{\max(\alpha_s,\beta_s)} \]

    因为满足以下的约束条件

    \[min(\alpha_i,\beta_i)+max(\alpha_i,\beta_i)=\alpha_i+\beta_i \]

    所以有

    \[gcd(a,b)\times lcm(a,b) =p_1^{\alpha_1+\beta_1}\cdot p_2^{\alpha_2+\beta_2}\cdot\cdot\cdot p_s^{\alpha_s+\beta_s} = a\times b \]

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

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

相关文章

Python编程快速上手:让繁琐工作自动化(第2版)PDF免费下载

Python编程从入门到实践姊妹篇,零基础自学Python教程书籍,提供配套同步教学视频、在线编程环境!针对Python3.X版本更新适读人群 :本书适合任何想要通过Python学习编程的读者,尤其适合缺乏编程基础的初学者。通过阅读本书,读者将能利用非常强大的编程语言和工具,并且体会…

几页画作

时长由于自己过于菜而痛不欲生而产生画画灵感……时光花火,水月星辰

学业之船航海记录——软工篇

这个作业属于哪个课程 https://edu.cnblogs.com/campus/fzu/SE2024这个作业要求在哪里 https://edu.cnblogs.com/campus/fzu/SE2024/homework/13315这个作业的目标 软工课程总结学号 102201118引言 上回说道,我的学业之船已在大学的海洋上行驶了一半的航程,这期间也遇到一些危…

这是篇博客

博客:软件工程实践课程回顾与总结 一、学期回顾 1.1 回顾你对于软件工程课程的想象 在学期开始之前,我对软件工程课程的期望在于提升编程能力。我想通过这门课程,能够深入了解软件开发流程中的实际操作,能够自主或协作实现开发出软件产品。 我原以为软件工程会是一个手把手…

苦尽甘来

一、学期回顾 1.1 回顾对于软件工程课程的想象 软件工程(实践者的研究方法)是一门研究如何以系统性的、规范化的、可定量的过程化方法去开发和维护软件,并运用计算机科学理论和技术以及工程管理原则和方法,按预算和进度要求开发和维护满足用户要求的软件产品的学科‌。‌在…

【杂谈】Kafka的日志段为什么不用内存映射?

什么是内存映射(Memory-Mapped File)? 内存映射(mmap)是一种将文件内容映射到内存中的技术,应用程序可以像操作内存一样对文件内容进行读写,而不需要显式地进行磁盘 I/O 操作。修改的内容会自动由操作系统同步到磁盘。 内存映射需要读取磁盘文件吗? 需要。毕竟,内存中…

【WEB安全】利用shuji还原webpack打包源码

一、前言二、webpack简介三、怎么确定是webpack打包站点呢四、shuji(周氏)配置4.1 安装nodejs环境4.2 安装shuji工具4.3 .js.map文件存放位置4.4 运行shuji 反编译.js.map文件获取源码4.5 代码审计五、实战记录免责声明 本公众号所分享内容仅用于网络安全技术讨论,切勿用于违…

万兴PDF专家绿色便携版

点击上方蓝字关注我 前言 万兴PDF一款非常实用的国产软件,它就像是一个超级工具箱,里面装满了处理PDF文件的各种工具。你可以用它来新建PDF、修改PDF里的内容、把PDF转成其他格式,还能给PDF签名、压缩大小、合并多个PDF,甚至比较两个PDF文件的不同。 这款软件的中文版设计得…

2024 第一届Solar应急响应

Tw0队伍 writeup 一、简介 欢迎有更好的解题思路一起交流学习。最好能来点写自动化一把梭工具的代码思路,哈哈哈! 二、 解题情况三、CTF题 签到题目描述: 本题作为签到题,请给出邮服发件顺序。 Received: from mail.da4s8gag.com ([140.143.207.229]) by newxmmxszc6-1.qq.co…

Python深度学习(第2版)PDF免费下载

流行深度学习框架Keras之父执笔,涵盖Transformer架构等进展,文字生,简单方式解释复杂概念,不用一个数学公式,利用直觉自然入门深度学习适读人群 :想要学习深度学习的学生、职业开发者。 流行深度学习框架Keras之父执笔,涵盖Transformer架构等进展,文字生,简单方式解释…

尝试 vmware 16.0.0 过虚拟化 过xf虚拟机检测

前言最新想在vmware虚拟机上玩xf,网上找了不少教程,于是打算自己尝试下。 如果可以修改成功的话,其价值嘛不可估量。 环境 vmware版本是16.0.0,已安装VMware Tools vmware版本是16.1.2,已安装VMware Tools 虚拟镜像cn_windows_7_professional_with_sp1_vl_build_x64_dvd_u…

【OpenGL ES】GLSL基础语法

1 前言 ​ 本文将介绍 GLSL 中数据类型、数组、结构体、宏、运算符、向量运算、矩阵运算、函数、流程控制、精度限定符、变量限定符(in、out、inout)、函数参数限定符等内容,另外提供了一个 include 工具,方便多文件管理 glsl 代码,实现代码的精简、复用。 ​ Unity…