鞋带定理
用于计算任意多边形面积
链接:https://blog.csdn.net/stereohomology/article/details/46942889
快速幂
链接:https://blog.csdn.net/qq_19782019/article/details/85621386
矩阵快速幂
链接:https://blog.csdn.net/zhangxiaoduoduo/article/details/81807338
错排问题
用递推实现
n 个不同元素的一个错排可由下述两个步骤完成:
第一步,“错排” 1 号元素(将 1 号元素排在第 2 至第 n 个位置之一),有 n - 1 种方法。
第二步,“错排”其余 n - 1 个元素,按如下顺序进行。视第一步的结果,若1号元素落在第 k 个位置,第二步就先把 k 号元素“错排”好,k 号元素的不同排法将导致两类不同的情况发生:
1、k 号元素排在第1个位置,留下的 n - 2 个元素在与它们的编号集相等的位置集上“错排”,有 f(n -2) 种方法;
2、k 号元素不排第 1 个位置,这时可将第 1 个位置“看成”第 k 个位置(也就是说本来准备放到k位置为元素,可以放到1位置中),于是形成(包括 k 号元素在内的) n - 1 个元素的“错排”,有 f(n - 1) 种方法。据加法原理,完成第二步共有 f(n - 2)+f(n - 1) 种方法。
根据乘法原理, n 个不同元素的错排种数
f(n) = (n-1)[f(n-2)+f(n-1)] (n>2) 。
素数筛法
https://www.cnblogs.com/grubbyskyer/articles/3852421.html
int快读
inline int read() |
说明:
inline
百度解释:inline关键字用来定义一个类的内联函数,引入它的主要原因是用它替代C中表达式形式的宏定义。
通俗解释:inline类似于#define,不过它可以来定义函数。
inline好处:这种宏定义在形式及使用上像一个函数,但它使用预处理器实现,没有了参数压栈,代码生成等一系列的操作,因此,效率很高。
通俗一点:inline可以提升速度。
register
register表示将变量放入寄存器中,所以很明显可以提升速度。