质数

 bool prime(int q)
{
if(q==||q==) return ;
if(q==) return ;
if(q%!=||q%!=) return ;
int cnt=sqrt(q);
for(int i=;i<=cnt;i+=)
if(q%!=||q%(i+)!=) return ;
return ;
}

 //埃氏筛 筛出1~n的素数
void prime_select()
{
for(int i=;i<=n;i++)
{
if(vis[i]) continue;
printf("%d\n",i);
for(int j=n;j<=n/i;j++) vis[i*j]=;
}
}

线性筛还是要学的qwq(真香),它的原理是每个合数会被它的最小质因子筛一次,利用了当前已经筛出的质数。复杂度真·O(N)

 //线性筛
void prime_select()
{
//v[]记录下标数的最小质因子 初值为0
for(int i=;i<=n;i++)
{
if(v[i]==) v[i]=i,prime[++m]=i;
for(int j=;j<=m;j++)
{//i是比prime[j]更小的质因子or超出n的范围
if(prime[j]>v[i]||prime[j]>n/i) break;
v[i*prime[j]]=prime[j];
}
}
}

 //质因数分解--基于算术基本定理 复杂度O(根号n)
void divide()
{
for(int i=;i<=sqrt(n);i++)
if(n%i==)
{
p[++m]=i;c[m]=;
while(n%i==) n/=i,c[m]++;
}
if(n>) p[++m]=n,c[m]=;
for(int i=;i<=m;i++)
printf("%d^%d\n",p[i],c[i]);
}

丢几个例题跑嘤嘤嘤

例题1 LuoguP1865 A%B Problem ---(本博客开通不久的旧文

   因为数据范围较水,仅1e6,所以我们可以先使用线性筛筛出素数。区间个数用前缀和维护。它珂以当做一个练线性筛的不错模板题。

例题2 UVA10140 Prime Distance  --(题解一篇

   我们知道,任意一个合数x一定包含不超过sqrt(n)的质因子。

   所以我们就筛出2~sqrt(R)之间的所有素数,用他们来标记全部范围内的合数。最后没被标记的数就是质数,比较相邻的质数位置取最大。

例题3 阶乘分解 没有题面,口胡一下。

   把N!分解质因数,按算术基本定理的形式输出。(N为1e6级别)

   N!中质因数p的个数就等于1~N每个数含质因子p的个数之和。其他...详见lyd书p131,不会用LaTex,懒得打了...

   时间复杂度O(Nlogn)

约数

//  这样写书式的复习我肯定干不完...以后会简洁一点...(真香)

  • 基于算术基本定理,N的正约数集合个数为(a1+1)*(a2+1)*(a3+1)*........*(an+1)(基于乘法原理)($a_i$为算术基本定理中的各指数)
  • 求1~N每个数的正约数集合--倍数法
//求1~N每个数的正约数集合--倍数法
void work()
{
vector<int>fac[];
for(int i=;i<=n;i++)
for(int j=;j<=n/i;j++)
fac[i*j].push_back(i);
}

复杂度为O(N+N/2+N/3+N/4+...+N/N)=O(NlogN)(调和级数)

例题1 LuoguP1463反素数

例题2 LuoguP2261余数之和

  • $gcd(a,b)*lcm(a,b)=a*b$
int gcd(int a,int b)
{
return b ? gcd(b,a%b) : a;
}//辗转相除
int gcd(int a,int b)
{
while(a!=b)
{
if(a>b)
a-=b;
else
b-=a;
}
return a;
}//更相减损
  • 欧拉函数:1~n中与n互质的数的个数

  • 1~n中与n互质的数的个数为$n*φ(n)/2$
  • 若a,b互质,则φ(a)φ(b)=φ(ab)。
  • 若n为质数,φ(n)=n-1
void phi()
{
phi[]=;
for(int i=;i<=n;i++) phi[i]=i;
for(int i=;i<=n;i++)
if(phi[i]==i)
for(int j=i;j<=n;j+=i)
phi[j]=phi[j]/i*(i-);
}
  • 费马小定理:当p为质数时候, a^(p-1)≡1(mod p)
  • exgcd:https://www.cnblogs.com/nopartyfoucaodong/p/9514767.html

组合数学

  • 求法:https://www.cnblogs.com/nopartyfoucaodong/p/9543206.html
  • 圆排列:https://www.cnblogs.com/nopartyfoucaodong/p/9751569.html
  • 第二类strling数:https://www.cnblogs.com/nopartyfoucaodong/p/9690393.html
  • 卡特兰数:https://www.cnblogs.com/nopartyfoucaodong/p/9752461.html

最新文章

  1. devenv命令详解
  2. [MySql] - 数据库备份还原
  3. itextpd f生成 pdf 文件
  4. 【转】【SSE】基于SSE指令集的程序设计简介
  5. 慕课网-安卓工程师初养成-3-3 Java中的赋值运算符
  6. Bug疑难杂症 - java.lang.NoSuchFieldError: udhLen
  7. Hibernate关联关系之双向1—n
  8. (转)在iOS中使用icon font
  9. python 学习笔记re
  10. leetcode学习笔记--开篇
  11. CLR via C# - Char_String - Format
  12. 新秀nginx源代码分析数据结构篇(两) 双链表ngx_queue_t
  13. Animation动画
  14. java线程 — 创建和启动线程
  15. Eclipse的操作技巧
  16. 学习笔记:UITabBarController使用详解
  17. 搭建docker私有仓库
  18. .Net转Java.04.踩到switch的坑
  19. vue 自学笔记(4): 样式绑定与条件渲染
  20. MySQL----数据库操作2

热门文章

  1. BZOJ 3671 NOI2014 随机数生成器
  2. log4net 初步使用
  3. Spring Boot2.0之 jar打包方式
  4. win下发现两个有用的快捷键
  5. .net 常用的插件列表
  6. 我的.emacs文件,用于C/C++及shell编程。
  7. openfire性能调优
  8. PostgreSQL与Oracle对应的函数
  9. 【LeetCode】Reverse Words in a String 反转字符串中的单词
  10. oracle 11g 常用命令