(上不了p站我要死了,侵权度娘背锅)

勉勉强强算是把数论复习的差不多了。

总结一下吧。

其实数论的知识大部分是结合在一起的,勉强分类总结

组合数

求法

组合数的求法根据不同情况选用不同的方法



2、3都是建立在模数为质数的基础上,而1、4适用于任何情况(数据范围内)。4的详细做法点这里

另外,阶乘的逆元可以o(n)求,以前一直用的o(nlogn)的。。具体做法点这里

卡特兰数

算是一种组合数的特殊运用。通常如果题目中有暗示“任何时候某数都大于等于另一个数”,就多半是卡特兰数。

卡特兰数的递推公式:C(2n,n)-C(2n,n+1)(记忆法点这里

直接公式:C(2n,n)/(n+1)

组合数的化简

有些时候列出来的式子太长,难以计算。可以通过组合数的等价转化和递推公式(杨辉三角)来化简式子。例如:bzoj4403

有以下的方法:

1、添项法:+1-1=C(n,n)-1

2、等价法:C(n,n)=C(n+1,n+1)

3、合并(拆项):C(n,m)=C(n-1,m)+C(n-1,m-1)

中国剩余定理(孙子定理)

基础公式

(mi两两互质)



M为所有的mi的乘积,Mi=M/mi,Mi^-1是在模mi意义下的逆元

证明很好证明,带进去化简,发现与上述的式子等价。

拓展孙子定理

使用于任意的mi,但是要复杂的多(这里就不赘述了)

主要的思路就是同于方程转化为等于方程,相当于解方程,合并上去。

在Lucas定理上的应用

Lucas定理的前提是模数为质数。当模数不为质数,但其质因子的指数都等于1时,可以用孙子定理来解决。例如:bzoj1951

线性筛与积性函数

这算不算是终于明白了线性筛?

之前考了一次线性筛筛积性函数,这个积性函数的陌生的,所以只能用一般套路。以前筛欧拉、莫比乌斯都是背的板子。。

详情点这里

欧拉函数

phi(i)表示1到i中与i互质的数的个数

对于欧拉函数,

一是灵活运用其定义,如bzoj2818(没写题解)

二是运用公式: 来解决一些有关gcd的问题

欧拉定理

费尔马小定理

拓展欧拉定理

常常用在幂运算的指数的取模上

拓展欧几里得

基本用途:解方程

拓展用途:求逆元(比欧拉定理求逆元来的快)

容斥原理

这是个高级玩意,以前一直都不太会用。一般有dfs的形式,也有线性的形式。还学到了一个快速统计子集和快速容斥的高级东西

矩阵

dp的快速递推

通常是这样的形式:



不一定是01,具体情况具体分析,现场模拟一下就好了。

因为有矩阵快速幂这玩意,所以对于递推的dp,可以很快的处理到10^7以上的项。

矩阵乘本身的性质

如hdu1257

朱爷太强了,%%%


大概就到这里吧

就复习了这些,整理一下

noip数论复习总结的更多相关文章

  1. 【数学】NOIP数论内容整理

    NOIP数论内容整理 注:特别感谢sdsy的zxy神仙以及lcez的tsr筮安帮助审稿 一.整除: 对于\(a,b~\in~Z\),若\(\exists~k~\in~Z\),\(s.t.~b~=~k~ ...

  2. NOIP考前复习-数制转换,数论模板与文件读写

    数制转换有两种题型,一般一题,分值1.5分. 题型一:R进制转十进制 解法就是:按权展开,但要注意各个位的权,最低位(最右边)的权是0次方,权值为1. 纯整数的情况: (11010110)2 = 1× ...

  3. NOIP 考前 数论复习

    POJ 2891 x=r1 (mod a1) x=r2 (mod a2) x=a1*x+r1,x=a2*y+r2; a1*x-a2*y=r2-r1; 用Extend_Gcd求出m1*x+m2*y=d; ...

  4. NOIp知识点复习——最短路计数

    $Mingqi\_H$ NOIp 2017考挂了...gg 重新开始好了. 计划明年2月24号前复习完所有的NOIp知识点(毕竟很不熟练啊),之后到七月底前学习完省选的东西(flag?). 从现在开始 ...

  5. NOIP系列复习及题目集合

    首先是我的酱油记了啦~: Xs的NOIP2014酱油记,持续更新中 知识点方面: noip知识点总结之--贪心 noip知识点总结之--线性筛法及其拓展 noip知识点总结之--欧几里得算法和扩展欧几 ...

  6. [NOIP 2014复习]第三章:动态规划——NOIP历届真题回想

    背包型动态规划 1.Wikioi 1047 邮票面值设计 题目描写叙述 Description 给定一个信封,最多仅仅同意粘贴N张邮票,计算在给定K(N+K≤40)种邮票的情况下(假定全部的邮票数量都 ...

  7. 11.7 NOIP总复习总结

    好像要1A模板题.完败 下面主要是一波SB错误总结 最小生成树(忘了sort(QwQ)) // It is made by XZZ // Fei Fan Ya Xi Lie~~~ #include&l ...

  8. NOIP专题复习1 图论-最短路

    一.知识概述 今天我们要复习的内容是图论中的最短路算法,我们在这里讲3种最短路求法,分别是:floyd,dijkstra,spfa. 那么我们从几道例题来切入今天讲解的算法. 二.典型例题 1.热浪 ...

  9. noip初赛复习总纲

    初赛复习总纲 目录 初赛复习总纲 计算机发展史 计算机的分类 计算机的应用 操作系统盘点 计算机的基本结构 中央处理器(**CPU**--**Central Processing Unit**) 存储 ...

随机推荐

  1. 团队Alpha版本冲刺(四)

    目录 组员情况 组员1(组长):胡绪佩 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:凯琳 组员6:丹丹 组员7:何家伟 组员8:政演 组员9:鸿杰 组员10:刘一好 组员:何宇恒 展示组内最新 ...

  2. Icarus Verilog和GTKwave使用简析

    Icarus Verilog和GTKwave使用简析 来源 http://blog.csdn.net/husipeng86/article/details/60469543 本文测试文件在window ...

  3. POJ 3090 Visible Lattice Points | 其实是欧拉函数

    题目: 给一个n,n的网格,点可以遮挡视线,问从0,0看能看到多少点 题解: 根据对称性,我们可以把网格按y=x为对称轴划分成两半,求一半的就可以了,可以想到的是应该每种斜率只能看到一个点 因为斜率表 ...

  4. org.apache.catalina.core.StandardWrapperValve.invoke Servlet.service() for servlet [WebApp] in context with path关于数据库库的问题

    1.在本地~~把你的查询的sql打印出来~~~然后拿到测试库里面执行一遍~~然后拿到正式库里面在执行一遍  2.看生产和本地~~1).代码不同步:2).就是数据为空问题 3.也有可能是数据库配置文件问 ...

  5. Download RPM packages from a YUM repo without installing

    This how-to will explain how to download rpm packages from a yum repository without installing them. ...

  6. POJ1200 Crazy Search

    Time Limit: 1000MS   Memory Limit: 65536KB   64bit IO Format: %I64d & %I64u Description Many peo ...

  7. 汕头市队赛 SRM14 T1 计算几何瞎暴力

    计算几何瞎暴力 (easy.pas/c/cpp) 128MB 1s 在平面上,给定起点和终点,有一面墙(看作线段)不能穿过,问从起点走到终点的最短路程. 输入格式 输入一行,包含8个用空格分隔的整数x ...

  8. 结构型设计模式之组合模式(Composite)

    结构 意图 将对象组合成树形结构以表示“部分-整体”的层次结构.C o m p o s i t e 使得用户对单个对象和组合对象的使用具有一致性. 适用性 你想表示对象的部分-整体层次结构. 你希望用 ...

  9. undefined reference to XXX 问题原因

    原文地址:http://blog.csdn.net/cserchen/article/details/5503556 Linux下编译程序时,经常会遇到“undefined reference to ...

  10. 判断dataset是否被修改—DataSet.HasChanges 方法

    DataSet.HasChanges 方法 获取一个值,该值指示 DataSet 是否有更改,包括新增行.已删除的行或已修改的行. 命名空间:   System.Data程序集:  System.Da ...