五一DAY1数论学习笔记

by ruanxingzhi

整除性

如果a能把b除尽,也就是没有余数,则我们称a整除b,亦称b被a整除。(不是除以,是整除!!

记作:\(a|b\)

|这个竖杠就是整除符号


整除的性质

  • 自反性

对于任意\(n\),有\(n|n\).

  • 传递性

若有\(a|b,b|c\),则\(a|c\).

  • 反对称性

如果\(a|b\),且\(b|a\),则\(a=b\)


约数和倍数

如果\(a|b\),那么\(a\)是\(b\)的约数,\(b\)是\(a\)的倍数。称\(a\)为\(b\)的因子。

从而得到重要推论:

任何数\(n\)至少有两个因子:\(1\)和\(n\)自身。我们将它们称为\(n\)的平凡因子。(其他的因子为非平凡因子)

\([1,n]\)的整数中,\(k\)的倍数有\(\frac{n}{k}\)个


计算

如何计算\([1,n ]\)中每个数的约数个数

n的约数个数记为\(d(n)\).要求给出一个\(O(n log n)\)的算法。

做法:暴力打标记

#include<bits/stdc++.h>
using namespace std;
int d[100005],n;
int main(){
cin>>n;
for(int i=1;i<=n;i++){
for(int j=1;i*j<=n;j++){
d[i*j]++;
}
}
for(int i=1;i<=n;i++){
printf("d[%d]=%d\n",i,d[i]);
}
return 0;
}

质数

质数是不存在非平凡因子的数

即只存在1和自己本身这两个约数的数

e.g.

\(2.3,5,7,19260817......\)


判断质数

求一个数是不是质数\(O(\sqrt{n})\)做法

bool prime(int x){
if(x==1)return false;
for(int i=2;i*i<=x;i++){
if(x%i==0)return false;
}
return true;
}

n的因子成对出现,一般情况下,\(n=a*b\),则a,b中一个大于等于\(\sqrt{n}\),一个小于等于\(\sqrt{n}\)


如何证明质数有无限个

【反证】假设质数有限

分别为\(p_1,p_2,p_3......p_n\)

有\(m=p_1*p_2*p_3*...*p_n+1\)

则\(m\%p_1=1,m\%p_2=1,m\%p_3=1.......m\%p_n=1\)


质数的性质

设\(π(n)\)为不超过\(n\)的质数个数。那么有:

$$π(n)\sim\frac{n}{ln;n}$$

\(π(n)\)是质数分布函数,\(n\)越大,质数的分布越稀疏


质数判断

朴素想法就是逐个判断,然而它的复杂度是\(O(n\;\sqrt{n})\)(It is so big!)

所以我们使用筛法(小学学的,就比如100以内的数筛去2,3,5,7的倍数之后剩下的数就都是质数了)

为什么我们不需要使用4,6,8,9这些合数去筛?

前面我们学过整除的传递性,在这里就能用上了

若\(a|b\),\(b|c\),则\(a|c\)

所以筛了2,一定筛了4,6,8

筛了3时,一定筛掉了6,9

所以这些数早就被筛过了

我们为何要再用他们去筛呢


代码实现

//埃氏筛法求素数
#include<bits/stdc++.h>
using namespace std;
bool notprime[10005]={0};
int main(){
int n,i,a;
cin>>n;
for(a=2;a<=n;a++){
if(notprime[a]==0){
printf("%d\t",a);
for(i=2;i*a<=n;i++){
notprime[i*a]=1;
}
}
}
}

更多素数的知识请参考这里

Mono_pigsicklie的有关素数的小结


质因数分解

每个数都可以拆成质数乘积的方式。这个过程叫做质因数分解。

\(5 = 5 = 5^1\)

\(15 = 3 * 5 = 3^1 * 5^1\)

\(36 = 2 * 2 * 3 * 3 = 2^2 * 3^2\)

我们可以保证:这样的分解方式是唯一的

质因数分解可以\(O(\sqrt{n})\)完成

//质因数分解
int work(int x,int p[]){
int cnt=0;
for(int i=2;i*i<=x;i++){
while(x%i==0){
p[cnt++]=i;
x/=i;
}
}
if(x>1)p[cnt++]=i;
return cnt;
}

回顾小学除法

一个数除以另一个数,得到商和余数

\(17÷5=3......2\) -----> \(17=\lfloor\frac{17}{5}\rfloor*5+17\%5=3*5+2\)

普遍的我们可以这样来表示除法:

$$a=\lfloor\frac{a}{p}\rfloor * p+a%p$$

其中\(p\)是除数,\(\lfloor\frac{a}{p}\rfloor\)是商,\(a\%p\)是余数

显然,如果p能将a整除,那么a ÷ p的余数为0.

也就是说:\(p|a\)当且仅当\(a\%p=0\).

所以,我们判断\(p\)能否整除\(a\),就只需要判断\(a\%p\)是否为\(0\)。

这很方便用代码实现。


模的性质

  • 值域

首先,由于模是取余,所以\(a\%p\)一定落在\([0, p -1]\)之间。

  • 随时取模性质

只含加法和乘法的式子中,如果最后的运算结果需要对\(p\)取模,那么你可以在运算过程中随便取模

只需要最后把结果对\(p\)再取模,答案就是正确的。


如何保证取模之后得到的数一定是正数?

公式:\((a\%b+b)\%b\)


GCD与LCM

\(gcd(a,b)\):\(a,b\)的最大公因数

\(lcm(a,b)\):\(a,b\)的最小公倍数

最大公约数,也称最大公因数、最大公因子,指两个或多个整数共有约数中最大的一个。\(a\),\(b\)的最大公约数记为\((a,b)\),同样的,\(a\),\(b\),\(c\)的最大公约数记为\((a,b,c)\),多个整数的最大公约数也有同样的记号。

求最大公约数有多种方法,常见的有质因数分解法、短除法、辗转相除法、更相减损法。与最大公约数相对应的概念是最小公倍数,\(a\),\(b\)的最小公倍数记为\([a,b]\)。

Small Quiz

如果我们把A分解成了\(2^{a_1}3^{a_2}5^{a_3}…\)

把B分解成了\(2^{b_1}3^{b_2}5^{b_3}…\)

1、如何快速求\(gcd(a,b)?\)

设\(d=2^{P_1}3^{P_2}5^{P_3}…\)

则很容易得到

\(P_1\le a_1,P_1 \le b_1\)

\(P_2\le a_2,P_2 \le b_2\)

\(P_3\le a_3,P_3 \le b_3…\)

所以a,b的最大公因数$$d=2{min(a_{1},b_1)}3{min(a_{2},b_2)}5^{min(a_3,b_3)}…$$

2、如何快速求\(lcm(a,b)?\)

类似的只要把上面的\(min\)改成\(max\)就好了

$$c=2{max(a_{1},b_1)}3{max(a_{2},b_2)}5^{max(a_3,b_3)}…$$

一个小式子:\(gcd(a,b)*lcm(a,b)=a*b\)

以a=1008,b=60为例:

\(1008=2^43^25^07^1\)

\(60=2^23^15^17^0\)

\(gcd(a,b)=2^23^15^07^0=\)

\(lcm(a,b)=2^43^25^17^1\)

\(gcd*lcm=2^23^15^07^02^43^25^17^1=1008*60\)


如何求GCD

直接给出两个数,如何求\(gcd(a,b)\)?

做法:GCD递归定理

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

等价的写法:\(gcd(a,b)=gcd(a\%b,b)\)

代码实现

\\递归
int gcd(int a,int b){
if(b==0)return a;
return gcd(b,a%b);
}
\\迭代
int gcd(int m, int n) {
while(m>0) {
int c=%m;
n=m;
m=c;
}
return n;
}

一条性质

记\(F[n]\)为斐波那契数列的第\(n\)项,则有

$$gcd(F[a],F[b])=F[gcd(a,b)]$$

求lcm

\(lcm(a,b)=a/gcd(a,b)*b\)

五一DAY1数论学习笔记的更多相关文章

  1. 数论学习笔记之解线性方程 a*x + b*y = gcd(a,b)

    ~>>_<<~ 咳咳!!!今天写此笔记,以防他日老年痴呆后不会解方程了!!! Begin ! ~1~, 首先呢,就看到了一个 gcd(a,b),这是什么鬼玩意呢?什么鬼玩意并不 ...

  2. 第一周 day1 Python学习笔记

    为什么要学习Python? Python擅长的领域 1. python2.x中不支持中文编码,默认编码格式为ASCII码,而python3.x中支持Unicode编码,支持中文,变量名可以为中文,如: ...

  3. 数论算法 剩余系相关 学习笔记 (基础回顾,(ex)CRT,(ex)lucas,(ex)BSGS,原根与指标入门,高次剩余,Miller_Rabin+Pollard_Rho)

    注:转载本文须标明出处. 原文链接https://www.cnblogs.com/zhouzhendong/p/Number-theory.html 数论算法 剩余系相关 学习笔记 (基础回顾,(ex ...

  4. 《从零开始学Swift》学习笔记http(Day1)——我的第一行Swift代码

    Swift 2.0学习笔记(Day1)——我的第一行Swift代码 原创文章,欢迎转载.转载请注明:关东升的博客 当第一次看到下面代码时我石化了,这些代码是什么东东?单词拼出来的? import Fo ...

  5. OpenCV图像处理学习笔记-Day1

    OpenCV图像处理学习笔记-Day1 目录 OpenCV图像处理学习笔记-Day1 第1课:图像读入.显示和保存 1. 读入图像 2. 显示图像 3. 保存图像 第2课:图像处理入门基础 1. 基本 ...

  6. Android学习笔记(五一):服务Service(上)- IntentService

    转自 http://blog.csdn.net/flowingflying/article/details/7616333 对于需要长期运行,例如播放音乐.长期和服务器的连接,即使已不是屏幕当前的ac ...

  7. sqli-labs学习笔记 DAY1

    DAY 1 准备工作 安装phpstudy 安装配置sqli-labs 学习笔记 SQL语句的注释:–, # +在URL经过编码后会编码为空格 SQL语句的查询语句:SELECT column_nam ...

  8. [学习笔记]NTT——快速数论变换

    先要学会FFT[学习笔记]FFT——快速傅里叶变换 一.简介 FFT会爆精度.而且浮点数相乘常数比取模还大. 然后NTT横空出世了 虽然单位根是个好东西.但是,我们还有更好的东西 我们先选择一个模数, ...

  9. 【转】 Pro Android学习笔记(五一):ActionBar(4):标准和Tab模式

    之前,我们学习的Action Bar是标准模式,Tab模式的如下图所示. 对于Tab,我们在Android学习笔记(二二): 多页显示-Tag的使用中学习过,但Action Bar的tab更适合fra ...

随机推荐

  1. IntelliJ IDEA 超实用使用技巧分享

    https://blog.csdn.net/weixin_38405253/article/details/102583954 知识点概览: 高效率配置 日常使用 必备快捷键(★★) 查找 跳转切换 ...

  2. c++小学期大作业攻略(四)任务系统+站内信

    虽然比最早的预定晚了整整一个星期但这核心功能最后一篇终于还是来了. 如果你已经经历了用户系统的洗礼,相信代码实现应该已经没有太大的难度,所以我们重点关注一下设计好的流程. 一.任务系统 首先是新建任务 ...

  3. Hbase Filter之FilterList

    作者:Syn良子 出处:http://www.cnblogs.com/cssdongl/p/7098138.html 转载请注明出处 我们知道Hbase的Scan经常需要用到filter来过滤表中的数 ...

  4. 【杂文】NOIP2018 蒟蒻自闭记

    [杂文]NOIP2018 蒟蒻自闭记 都 \(9102\) 年了,谁还记得 \(2018\) 年的事啊 \(QAQ\) . 还有两个月就要去参加首届 \(CSP\) 了. 想着如果再不记下去年那些事儿 ...

  5. torch.max

    torch.max() torch.max(input) -> Tensor Explation: ​ Returns the maximum value of all elements in ...

  6. “sgen.exe”未能运行。文件名或扩展名太长

    问题 创建项目后无法运行 严重性 代码 说明 项目 文件 行 禁止显示状态 错误 MSB6003 指定的任务可执行文件"sgen.exe"未能运行.System.Component ...

  7. Flask send_file request

    send_file: send_file( filename_or_fp, mimetype=None, as_attachment=False, attachment_filename=None, ...

  8. 2019 浩德钢圈java面试笔试题 (含面试题解析)

      本人5年开发经验.18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴.今日头条.浩德钢圈等公司offer,岗位是Java后端开发,因为发展原因最终选择去了浩德钢圈,入职一年时间了,也成为了面 ...

  9. 【JZOJ】2126. 最大约数和

    题目大意 选取和不超过S的若干个不同的正整数,使得所有数的约数(不含它本身)之和最大. 分析 把我们分解出来的因数进行合并,存在一个不知名的数组里,然后我们大可开始我们的迪屁!!(bag),我们可以 ...

  10. Java中assert(断言)的使用

    Java中assert(断言)的使用 1.Eclipse中默认assert(断言)是关闭,开启方式如下: 简单来说:就是设置一下jvm的参数,参数是-enableassertions或者-ea(推荐) ...