总得来说,这是可怕的一天,极其可怕的一天(完)

一、数论

阴影啊!

首先,设ab为两个整数,则存在唯一的q和r,使得a=qb+r

若r=0,则b整除a,记作b|a。

(1)同余

若a/m和b/m的余数相同,则称a于b对模m同余,记作a ≡ b (mod m)

剩余系:在模 m 的意义下,余数相同的数归为一个集合,那么所有整数被分为 m个不同的集合,模 m 的余数分别为 0,1,2,3,...,m − 1,这些集合被称为模 m 剩余类(同余类)。每个同余类中的任意两个整数都是模 m 同余的。__by dzy(就是模m的余数集合)

若是剩余系遍历了0~m-1,则叫做完全剩余系

  • 同余式的三则运算:
  • 设 a,b,c,d 为整数,m 为正整数,若 a ≡ b (mod m),c ≡ d(mod m),则:

  • ax + cy ≡ bx + dy (mod m),其中 x,y 为任意整数,即同余式可以相加()
  • ac ≡ bd (mod m),即同余式可以相乘a n ≡ b n (mod m),其中 n > 0
  • f(a) ≡ f(b) (mod m),其中 f(x) 为任一多项式。
  • a n ≡ b n (mod m),其中 n > 0

(2)素数

判断素数的方法:一般是从2开始,枚举到√ n,依次判断i是否能整除n,若n=pq,则pq中的一个必定小于等于√ n。

但是,如果硬生生跑√ n,那么如果需要素数的话可能会把评测姬卡哭喔

所以我们需要:

素数筛

原理1:考虑在每找到一个素数的时候把它的倍数也标记上。这样就可以实现:大大减少

复杂度:O(nloglogn)基本达到线性。

但是它还有优化的空间:

比如12,跑到2的时候它被筛了一次,跑到3的时候它又被干了一次

所以极端情况评测姬还是会被卡哭....

我们强制命令每一个数都只被它的最小质因数给筛去,

于是,伟大的线性筛出生了

原理2:每一个数都只被它的最小质因数给筛去

下for解释:

如果大于上界,退出,

标记非质数

如果i被之前的素数筛过了(这里保证了线性,即每个数只来一遍)

三、欧拉函数(φ(n))是指不超过n且与n互质的数的个

  • p是一个质数,则φ(p)=p-1(除了1都与p互质)(逆定理依旧成立)
  • p是质数,a是正整数,则(显然只有p的倍数与p^a 不互质,故可得到上式)
  • 如果mn互质,则φ(mn)=φ(m)*φ(n)必须互质!!(证明长啊。。。甩个链接https://cdn.luogu.org/upload/pic/69862.png)

欧拉定理:如果a,m互质,那么:

此证明不难理解:

*x1 * x2 * x3.....xφ(m)≡x1 * x2 * x3.....xφ(mod m)

同除

x1x2x3......

常用的是:费马小定理

当 p 是质数,a ̸= p 时,有 a p−1 ≡ 1 (mod p)。。

广义欧拉定理:

证明是真的不会....放链接https://blog.csdn.net/zxyoi_dreamer/article/details/82929466

四、gcd部分

lcm(最小公倍数)(a,b)=ab/gcd(a,b);

求算gcd:欧几里得算法(辗转相除)

原理:gcd(a,b)=gcd(b,a-b)

设 (a,b) = g,a = cg,b = dg,那么 (c,d) = 1。
(b,a − b) = (d,c − d)g。
如果 (d,c − d) = q ̸= 1,那么 (c,d) ≥ q ̸= 1,矛盾。
所以 (b,a − b) = (d,c − d)g = g。

所以gcd就诞生了

int gcd(int a,int b)
{
if(b==)return a;
else gcd(b,a%b);
}(短小精悍)

exgcd(一次不定方程)

考虑求解方程:ax+by=c

有解的情况是:gcd(a,b)|c。

当b=0,gcd(a,b)=a;

当b!=0,gcd(a,b)=gcd(b,a%b);

所以原方程——>bx2+(a%b)y2=gcd(b,a%b)

于是我们就可以递归求解。

五、逆元

在一些情况下,(比如组合数)要边除边膜,这样可能暴毙。。。

所以逆元登场了。除一个数等于乘一个数的倒数,所以逆元就是除数膜的倒数

来看看正经的定义:

若(a,m)=1,且ab≡ 1 (mod m),则b就是a%m意义下的逆元。

(a/b≡ a ∗ c (mod m))

求解逆元的方法:

1、费马小定理

根据定义,ab≡ 1 (mod m),及费马小定理,得:

所以a^(p-2)*a≡1(mod p)所以得a^p-2是a的逆元

2、exgcd

已知exgcd可用于求解ax+by=1的解,那么exgcd怎么求算逆元呢?

如果ax+by=1,则ax≡1(mod m)所以x就是a在模m意义下的逆元。

3、线性递推

https://www.cnblogs.com/qdscwyy/p/7795368.html

六、多元一次不定方程

1、二元一次不定方程

exgcd.....系数同除以c,然后解再乘上c就行了

2、多元方程组

n元一次不定方程:

当且仅当(a1; a2; :::; an)|c,方程有解。

怎么解呢?

设(a1; a2) = d2; (d2; a3) = d3; :::; (dn-1; an) = dn,那么方程等价于:

于是可以从最后一个开始求,然后代回去,直到第一个。

3、一元线性同于方程:

形如ax≡b (mod m)

等价于ax-my=b,直接exgcd即可。

形如

的可爱方程组~(彻底败给了dzy大神的讲解顺序啊....先exCRT再CRT.....真的醉了)

(1)CRT解法 限制:m1,m2,互质,若m不互质,甚至可以质因数分解强行互质.....

令ei=1/Mi*Mi mod m

则:

所以,

(2)exCRT(合并法)

考虑两两合并:

由于x≡b(mod m)等价于x-my=b,

当:

根据上述展开,得

所以,我们令m=lcm(m1,m2),此方程就变成了:

最后得到一个方程,那么这个解就是最终解

七、神仙

实在是看不懂,老师也没有讲,果然还是我太弱了

day3(数论)的更多相关文章

  1. Day3:T1数论+高精 T2搜索

    T1:数论+高精(水~) 根据题意可知,从除的数越大越好(在0~9中) 所以我们只要用到高精除然后再模拟一下就可以了 //MARK:但是要注意0-9这个特殊值需要特判,因为题目要求输出的数至少是两位数 ...

  2. 【CCPC-Wannafly Winter Camp Day3 (Div1) F】小清新数论(莫比乌斯反演+杜教筛)

    点此看题面 大致题意: 让你求出\(\sum_{i=1}^n\sum_{j=1}^n\mu(gcd(i,j))\). 莫比乌斯反演 这种题目,一看就是莫比乌斯反演啊!(连莫比乌斯函数都有) 关于莫比乌 ...

  3. 简单数论 | Day3 部分题解

    A - The Euler function 来源:HDU 2824 计算[a,b]区间内的整数的欧拉函数值,需要掌握单个欧拉函数和函数表的使用. #include <iostream> ...

  4. qbxt Day3 on 2019-8-18

    qbxt Day3 on 2019-8-18 一.基础数论 1.进制转换 进制转换是一个非常简单且基础的问题. 也许我们只需要...Emmm... 列个式子就好了鸭 设\(k\)进制数每一位上是\(a ...

  5. Codeforces Round #382 Div. 2【数论】

    C. Tennis Championship(递推,斐波那契) 题意:n个人比赛,淘汰制,要求进行比赛双方的胜场数之差小于等于1.问冠军最多能打多少场比赛.题解:因为n太大,感觉是个构造.写写小数据, ...

  6. NOIP2014 uoj20解方程 数论(同余)

    又是数论题 Q&A Q:你TM做数论上瘾了吗 A:没办法我数论太差了,得多练(shui)啊 题意 题目描述 已知多项式方程: a0+a1x+a2x^2+..+anx^n=0 求这个方程在[1, ...

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

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

  8. hdu 1299 Diophantus of Alexandria (数论)

    Diophantus of Alexandria Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java ...

  9. 【BZOJ-4522】密钥破解 数论 + 模拟 ( Pollard_Rho分解 + Exgcd求逆元 + 快速幂 + 快速乘)

    4522: [Cqoi2016]密钥破解 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 290  Solved: 148[Submit][Status ...

随机推荐

  1. jsp隐含对象(内置对象)

    JSP共有以下9个内置的对象: request HttpServletRequest类的实例,用户端请求,此请求会包含来自GET/POST请求的参数 response HttpServletRespo ...

  2. docker升级后启动报错400 Client Error: Bad Request ("Unknown runtime specified docker-runc")

    宝塔面板docker升级后启动容器时报错400 Client Error: Bad Request ("Unknown runtime specified docker-runc" ...

  3. css浮动产生和清除浮动的几种方式

    浮动的语法:float:left/right; 浮动float的原本设计了作用初衷是为了实现文字环绕效果 浮动产生负作用: 1.背景不能显示 2.边框不能撑开父元素 3.margin padding设 ...

  4. RE-1 逆向分析基础

    逆向分析基础 0x01-0x0C 本笔记使用汇编指令为x86架构下汇编指令,ARM架构汇编指令不做介绍 0x01. 关于RE 逆向工程(Reverse Engineering RE) 逆向分析方法: ...

  5. 部署主从dns

    主机部署:yum安装DNS服务和依赖 [admin@haifly-bj-dns1 ~]$ sudo yum install bind-chroot启动named-chroot服务 [admin@hai ...

  6. Go routine 编排框架:oklog/run 包

    目录 Go routine 编排框架:oklog/run 包 问题引入 oklog/run 包介绍 使用例子 参考资料 Go routine 编排框架:oklog/run 包 问题引入 oklog/r ...

  7. 怎么将ETL技术落地

    ETL概述 ETL(Extraction-Transformation-Loading)是将业务系统的数据经过抽取.清洗转换之后加载到数据仓库的过程,目的是将企业中的分散.零乱.标准不统一的数据整合到 ...

  8. Jenkins项目构建

    一:新建项目 (1)点击新建,输入项目名称--构建一个自由风格的软件项目,点击ok (2)创建项目名称,选择节点标签 (3)构建触发器-----设置每两分钟执行一次 其中有5个参数 (*****) 第 ...

  9. 《锋利的jQuery》学习总结

    通过对<锋利的jQuery>(第二版)一书的学习,发现此书讲解通俗易懂,是学习jQuery的一本很好的指导书,特作如下总结.此书主要讲解了jQuery的常用操作,包括认识jQuery,jQ ...

  10. 浅谈爬虫 《一》 ===python

    浅谈爬虫 <一> ===python  ‘’正文之前先啰嗦一下,准确来说,在下还只是一个刚入门IT世界的菜鸟,工作近两年了,之前做前端的时候就想写博客来着,现在都转做python了,如果还 ...