数论知识点:

约数个数和约数和公式(例题:POJ1845 分治思想):

质因数分解 p1^k1xp2^k2xp3^k3...pn^kn

约数个数和(1+k1)(1+k2)...(1+kn)

所有约数和=(1+p1+p1^2+...+p1^k1)...(1+pn+pn^2+...+pn^kn)

求和方法:因式分解+分治

            或者等比数列求和+拓展GCD求逆元

欧拉定理:若GCD(x,y)≡1,则x^(φ(y))≡1(mode y)

      特殊:费马小定理:若y是质数,且x,y互质,则x^(y-1)≡1 (mode y)

推论:降幂公式:若GCD(x,y)≡1,则a^x≡a^(x%φ(y))(mode y)

            若GCD(x,y)≠ 1,则a^x≡a^(x%φ(y)+φ(y))(mode y)

欧拉函数φ(x),其中若x为质数,则φ(x)=x-1,且欧拉函数为积性函数(人话:可以线性筛!!!

gcd与lcmGCD(x,y)xLCM(x,y)=xy

拓展GCDax≡y (mod p)

刚刚写计算器,发现我对拓展gcd的理解出现了漏洞......

(我发现我忽略了使用拓展gcd的第一步,上来就递归......)

使用拓展gcd步骤如下:

                给定不定方程ax≡y(mode p)
首先求gcd(a,p)=t ①
若y mode t !=0,则原方程无整数解
若y mode t = 0,则:
a/=t,y/=t,p/=t ②
即将原方程化为a0x+p0z=y0的形式
接下来求出a0x+p0z=1 ③的一组整数解x0,z0
此时才用到拓展gcd
其解法:辗转相除至b=0,此时赋值x=1,y=0,回溯时修改x=y0,y=x0-(a/b)y0
然后再算出x=y0*x0+kp0(k∈Z)
z=y0*z0+kp0(k∈Z) ④
最后化出正整数(取模加模再取模)即可 ⑤
所以拓展gcd是至少有5步的!
(然而我只记得辗转相除再赋值...所以计算器WA了一下午...)

求逆元:拓展GCD,费马-欧拉定理,线性筛

中国剩余定理:已知

            x%a0≡a1,x%b0≡b1,x%c0≡c1

            令M1=b0xc0,M2=a0xc0,M3=a0xb0

            则原方程可变为:

            M1x1≡1(mode a0)

            M2x2≡1(mode b0)

            M3x3≡1(mode c0)

            显然可用拓展gcd解出x1,x2,x3

            那么,所求x=(M1a1x1+M2a2x2+M3a3x3)%(LCM(a0,b0,c0))

结论:中国剩余定理给出了一系列模方程组,可以采用拓展GCD将上述方程拓展到n个,采用拓展gcd解之即可

通解: 对于x%a0≡b0...等一系列方程组

            我们可以令M=Πai

            对于每一个xi,求出Mixi≡1(mode ai)的xi

            其中Mi=M/ai

            则最终所求的x=Σ(Mibixi)%M

            例:曹冲养猪

线性筛:线性筛可以筛:

            素数+欧拉函数:

            void eular()
{
for(int i=2;i<=maxN;i++)
{
if(used[i]==0)
{
prime[++cnt]=i;
phi[i]=i-1;
}
for(int j=1;j<=cnt&&i*prime[j]<=maxN;j++)
{
used[i*prime[j]]=1;
if(i%prime[j]==0)
{
phi[i*prime[j]]=phi[i]*prime[j];
break;
}else
{
phi[i*prime[j]]=phi[i]*(prime[j]-1);
}
}
}
} 素数+约数个数: void make(int n)//线性筛
{
f[1]=1;//初值
for(int i=2;i<=n;i++)
{
if(used[i]==0)//未被标记
{
f[i]=2;//该数为素数
p[++cnt]=i;
d[i]=1;//该数最大次数为1
}
for(int j=1;j<=cnt&&i*p[j]<=n;j++)
{
used[i*p[j]]=1;//打标记
if(i%p[j]==0)//该数中有这一质因子
{
f[i*p[j]]=f[i]/(d[i]+1)*(d[i]+2);//此二数之积的因数个数应为其中一数的因数个数再多一个该质数
d[i*p[j]]=d[i]+1;//最小质因子最高次幂就是其加上1
break;
}
f[i*p[j]]=f[i]*2;//搞定
d[i*p[j]]=1;
}
}
} 对模mode的逆元: void init()
{
inv[1]=1;
for(int i=2;i<=maxn;i++)
{
inv[i]=(mode-mode/i)*inv[mode%i]%mode;
}
inv[0]=1;
for(int i=1;i<=maxn;i++)
{
inv[i]=inv[i-1]*inv[i]%mode;
}
jiecheng[1]=1;
for(int i=2;i<=maxn;i++)
{
jiecheng[i]=jiecheng[i-1]*i%mode;
}
}

以及混合起来的万能筛:

 #include <cstdio>
#define mode 998244353
#define maxn 1000000
using namespace std;
bool used[1000006];
int prime[1000006];//素数
int fac[1000006];//约数个数
int mi[1000006];//约数的最高次幂
int inv[1000006];//对mode的逆元
int phi[1000006];//欧拉函数
int cnt=0;
void init()
{
inv[0]=1;
inv[1]=1;
fac[1]=1;
for(int i=2;i<=maxn;i++)
{
inv[i]=(mode-mode/i)*inv[mode%i]%mode;
if(!used[i])
{
prime[++cnt]=i;
fac[i]=2;
mi[i]=1;
phi[i]=i-1;
}
for(int j=1;j<=cnt&&i*prime[j]<=maxn;j++)
{
used[i*prime[j]]=1;
if(i%prime[j]==0)
{
fac[i*prime[j]]=fac[i]/(mi[i]+1)*(mi[i]+2);
mi[i*prime[j]]=mi[i]+1;
phi[i*prime[j]]=phi[i]*prime[j];
break;
}
phi[i*prime[j]]=phi[i]*phi[prime[j]];
fac[i*prime[j]]=fac[i]*2;
mi[i*prime[j]]=1;
}
}
}
int main()
{
init();
for(int i=1;i<=cnt;i++)
{
printf("%d\n",prime[i]);
}
return 0;
}

数论知识点总结(noip范围)的更多相关文章

  1. NOIp 基础数论知识点总结

    推荐阅读 NOIp 数学知识点总结: https://www.cnblogs.com/greyqz/p/maths.html Basic 常用素数表:https://www.cnblogs.com/g ...

  2. Collections 索引

    About Me NOIp 数据结构专题总结 NOIp 图论算法专题总结 NOIp 基础数论知识点总结 NOIp 数学知识点总结 搜索算法总结 (不包含朴素 DFS, BFS) 位运算 字符串算法总结 ...

  3. Noip前的大抱佛脚----数论

    目录 数论 知识点 Exgcd 逆元 gcd 欧拉函数\(\varphi(x)\) CRT&EXCRT BSGS&EXBSGS FFT/NTT/MTT/FWT 组合公式 斯特林数 卡塔 ...

  4. NOIp 数学知识点总结

    推荐阅读 NOIp 基础数论知识点总结: https://www.cnblogs.com/greyqz/p/number.html 排列组合 常用公式 排列:\[\displaystyle A_n^m ...

  5. Codevs 1200 同余方程 2012年NOIP全国联赛提高组

    1200 同余方程 2012年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 求关于 x 同余方程 a ...

  6. WC2019 20天训练

    Day -1 2019.1.2 初步计划: 0x60 图论 std 洛谷提高剩余练习 NOIP2018遗留题解 洛谷省选基础练习 数学: 1.数论 2.组合数学(练习:莫比乌斯反演) 3.概率(练习: ...

  7. [HNOI2002]跳蚤 【容斥】

    题目描述 Z城市居住着很多只跳蚤.在Z城市周六生活频道有一个娱乐节目.一只跳蚤将被请上一个高空钢丝的正中央.钢丝很长,可以看作是无限长.节目主持人会给该跳蚤发一张卡片.卡片上写有N+1个自然数.其中最 ...

  8. 扩展gcd codevs 1200 同余方程

    codevs 1200 同余方程 2012年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题目描述 Description 求关 ...

  9. Noip知识点备考

    作为一个oier,适当的整理是有必要的.蒟蒻根据自己的理解,筛选出考noip应当掌握的知识点.可能后期还有解题思路和模板,先挖个坑慢慢补呗. 60级张炳琪Noip知识点总结 可能是本人比较弱,写的内容 ...

随机推荐

  1. 移动端自动化测试-Windows-Android-Appium环境搭建

    1.安装JDK,并且配置好[JAVA_HOME]和[path]两个环境变量 1.1.JAVA_HOME:指向JDK的安装路径(如:C:\Program Files (x86)\Java\jdk1.7. ...

  2. Post和get请求时中文乱码

    在web.xml中加入: <filter> <filter-name>CharacterEncodingFilter</filter-name> <filte ...

  3. 获取天气预报API

    sklearn实战-乳腺癌细胞数据挖掘(博主亲自录制视频) https://study.163.com/course/introduction.htm?courseId=1005269003& ...

  4. Scala进阶之路-并发编程模型Akka入门篇

    Scala进阶之路-并发编程模型Akka入门篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Akka Actor介绍 1>.Akka介绍 写并发程序很难.程序员不得不处 ...

  5. JAVA记录-SpringMVC+Mybatis几个核心注意的地方

    1.DispatcherServlet   -- 前置控制器 DispatcherServlet是一个Servlet,所以可以配置多个DispatcherServlet. DispatcherServ ...

  6. PHP7 学习笔记(十)会话控制

    防守打法 1.设置Cookie,[基于内存的Cookie] setcookie('Username','tinywan'); setcookie('Age','24'); 2.查看Cookie存储位置 ...

  7. ps知识集锦

    1.工具箱   移动工具 [V]矩形.椭圆选框工具 [M]套索.多边形套索.磁性套索 [L]快速选择工具.魔棒工具 [W] 裁剪.透视裁剪.切片.切片选择工具 [C]吸管.颜色取样器.标尺.注释.12 ...

  8. 从池子里的beta看秋香, 个性迥异

    从池子里的beta看秋香, 个性迥异 前文里那十只个股为例, 统计了它们的beta值. 回顾如下: Num name code Beta 0 深圳燃气 601139 0.710 公用事业 1 分众传媒 ...

  9. Python排序算法之冒泡排序

    冒泡排序 顾名思义,冒泡排序直观的意思是气泡越大冒的越快:),对应到我们的列表中就是数字最大的先选出来,然后依次进行.例如 myList = [1,4,5,0,6],比较方式为: 相邻的两个数字先进行 ...

  10. ELF文件解析(一):Segment和Section

    ELF 是Executable and Linking Format的缩写,即可执行和可链接的格式,是Unix/Linux系统ABI (Application Binary Interface)规范的 ...