前言

感觉距离scoi2019scoi2019scoi2019的时间不多了博主因为太弱所以现在慌得一批,现在尝试梳理一些小知识点顺便复习。

素数与同余

线性筛部分

常识向,直接贴代码了,大佬们手动跳过吧。

最常用的是线性筛质数。

同时有两种常用的可以线性筛预处理的函数:莫比乌斯函数,欧拉函数。

线性筛代码:

typedef long long ll;
ll prime[N],pri[N],cnt=0,mu[N],phi[N];
inline void init(int len){
	mu[1]=phi[1]=1;
	for(int i=2;i<=len;++i){
		if(!pri[i])prime[++cnt]=i,mu[i]=-1,phi[i]=i-1;
		for(int j=1;i*prime[j]<=len;++j){
			pri[i*prime[j]]=1;
			if(i%prime[j]==0){
				phi[i*prime[j]]=phi[i]*prime[j];
				mu[i*prime[j]]=0;
				break;
			}
			mu[k]=-mu[i];
			phi[k]=phi[i]*(prime[j]-1);
		}
	}
}

素数

线性递推逆元

指数循环节降幂

当求逆元时模数与求逆元的数有可能不互质时的处理方法

一个神奇的结论

有个结论,对于 m >= 2,与m的互质的数的和为m * phi (m) / 2

拓展欧拉定理

杂乱的一些性质/技巧

二进制枚举子集

这是一个用循环实现的快速枚举子集的方法,代码如下:

for(int i=s;i;i=s&(i-1))

异或前缀和

一个蒟蒻博主听说可以打表证明的性质:

sumi=i,i≡0mod&ThinSpace;&ThinSpace;4sum_i=i,i\equiv0 \mod4sumi​=i,i≡0mod4

sumi=1,i≡1mod&ThinSpace;&ThinSpace;4sum_i=1,i\equiv1 \mod4sumi​=1,i≡1mod4

sumi=i+1,i≡2mod&ThinSpace;&ThinSpace;4sum_i=i+1,i\equiv2 \mod4sumi​=i+1,i≡2mod4

sumi=0,i≡3mod&ThinSpace;&ThinSpace;4sum_i=0,i\equiv3 \mod4sumi​=0,i≡3mod4

感觉挺有用的

O(n)预处理popcount

popcount(x)popcount(x)popcount(x)指xxx在二进制形式中二进制位为111的数量。

直接处理是O(logx)O(log_x)O(logx​)的,但是可以O(amax)O(a_{max})O(amax​)预处理。

代码:

for(int i=1;i<=lim;++i)Popcount[i]=Popcount[i>>1]+(i&1);

原理很简单(逃

多项式一类

因为太多之前特意写了一篇博客 才不是骗访问量呢

组合数学

卡特兰数通项

Catn=C2nn−C2nn−1=C2nnn+1Cat_n=C_{2n}^n-C_{2n}^{n-1}=\frac{C_{2n}^n}{n+1}Catn​=C2nn​−C2nn−1​=n+1C2nn​​

斯特林数

两类可以用fftfftfft预处理做到O(nlogn)O(nlogn)O(nlogn)

但是一般都只用O(n2)O(n^2)O(n2)(雾

下面给出递推式:

第一类斯特林数递推式:





第二类斯特林数递推式:





错排公式

看了这道题你就懂了。

递推式:fi=(i−1)(fi−1+fi−2)f_i=(i-1)(f_{i-1}+f_{i-2})fi​=(i−1)(fi−1​+fi−2​)

二项式反演

fn=∑i=0n(ni)gif_n=\sum_{i=0}^n\binom{n}{i}g_ifn​=∑i=0n​(in​)gi​

=>gn=∑i=0n((−1)i(nn−i)fi)g_n=\sum_{i=0}^n((-1)^i\binom{n}{n-i}f_i)gn​=∑i=0n​((−1)i(n−in​)fi​)

可以看这道题简单体会一下。

数学小知识点整理(TBC)的更多相关文章

  1. 求职之C++小知识点整理

    1.顺序容器 1.顺序容器:vector,deque,list,forward_list,array,string.其中除list和forward_list外,其它都支持快速随机访问. deque a ...

  2. Oracle数据库小知识点整理

    -- 数据库存储数据 -- 市面上主流的数据库有哪些 -- 甲骨文  oracle   mysql --  IBM  db2  金融 --  微软  sqlserver --这些是关系型数据库. -- ...

  3. 一些js小知识点整理

    string.substring(a,b)   从a点开始截取,到b点结束 string.substr(a,b)    从a点开始截取,截取b个 BOM的四个对象,navigator.screen.l ...

  4. Django小知识点整理

    一.Django中Choices字段显示中文的两种方式 1.get_xxxx_display():这种方式只能针对对象来使用 {% for row in server_list %} <li&g ...

  5. 【转】HTML5的小知识点小集合

    html5的小知识点小集合 html5知识   1.  Doctype作用?标准模式与兼容模式各有什么区别? (1).<!DOCTYPE>声明位于位于HTML文档中的第一行,处于<h ...

  6. html5的小知识点小集合

      html5的小知识点小集合 html5知识   1.  Doctype作用?标准模式与兼容模式各有什么区别? (1).<!DOCTYPE>声明位于位于HTML文档中的第一行,处于< ...

  7. kafka知识点整理总结

    kafka知识点整理总结 只不过是敷衍 2017-11-22 21:39:59 kafka知识点整理总结,以备不时之需. 为什么要使用消息系统: 解耦 并行 异步通信:想向队列中放入多少消息就放多少, ...

  8. JS知识点整理(二)

    前言 这是对平时的一些读书笔记和理解进行整理的第二部分,第一部分请前往:JS知识点整理(一).本文包含一些易混淆.遗漏的知识点,也会配上一些例子,也许不是很完整,也许还会有点杂,但也许会有你需要的,后 ...

  9. activity生命周期知识点整理

    activity生命周期知识点整理 Activity: 是一个应用组件,用户可与其提供的屏幕进行交互.窗口通常会充满屏幕,但也可以小于屏幕并浮动在其他窗口之上. 一个activity的什么周期: 启动 ...

随机推荐

  1. POJ-3078.Shuffle'm Up(简单模拟题)

    这道题做了有四个小时吧,今天一整天都处于边玩边学的状态,我很是不喜欢...一开始用了20分钟模拟,过了样例后TLE了,就在考虑是不是判断是否重复判定的数组开大了,结果一直蛙,后面想到了map判重,结果 ...

  2. javascript实现留言功能

    原理: 1.用户在留言框输入留言 2.利用textarea的value属性获取到用户输入的留言 3.动态创建一个li 4.将获取的留言打包成html存到li中 5.根据需要添加删除留言.统计留言数量等 ...

  3. angular小技巧随笔

    1. 重新刷新页面 同页面切换状态: $state.go('tab.index', {inviteId:inviteId}); self.location.reload();

  4. TZOJ 1513 Farm Tour(最小费用最大流)

    描述 When FJ's friends visit him on the farm, he likes to show them around. His farm comprises N (1 &l ...

  5. Django xadmin后台添加富文本编辑器UEditor的用法

    效果图: 步骤: 1.利用命令:pip install DjangoUeditor,安装DjangoUeditor,但由于DjangoUeditor没有python3版本的,从的Github上把修改好 ...

  6. shell加密工具shc的安装和使用

    1) 工具说明 shell脚本是可读写的, 很有可能会泄露敏感信息, 如用户名/密码/路径/IP等. 同样在shell脚本运行时会也泄露敏感信息. shc是一个加密shell脚本的工具, 它的作用是把 ...

  7. 异常处理 day 30

    异常处理 一 错误和异常 二 异常处理 2.1 什么是异常处理? 2.2 为何要进行异常处理? 2.3 如何进行异常处理? 三 什么时候用异常处理 异常和错误 part1:程序中难免出现错误,而错误分 ...

  8. Oracle_高级功能(7) 数据字典视图和动态性能视图

    oracle数据字典 1.概念数据字典是oracle数据库用来存储数据库结构信息的地方.数据字典是用来描述数据库数据的组织方式的,由表和视图组成.数据字典基表是在任何 Oracle 数据库中创建的第一 ...

  9. $ each() 小结

    each()方法能使DOM循环结构简洁,不容易出错.each()函数封装了十分强大的遍历功能,使用也很方便,它可以遍历一维数组.多维数组.DOM, JSON 等等在javaScript开发过程中使用$ ...

  10. 程序员"装B"手册

    一.准备工作 “工欲善其事必先利其器.” 1.电脑不一定要配置高,但是双屏是必须的,越大越好,能一个横屏一个竖屏更好.一个用来查资料,一个用来写代码.总之要显得信息量很大,效率很高. 2.椅子不一定要 ...