noip考前抱佛脚 数论小总结
exCRT
- 求解韩信点兵问题,常见的就是合并不同\(mod\)。
- 先mo一发高神的板子
for(R i=2;i<=n;++i){
ll Y1,Yi,lcm=Lcm(p[i],p[1]);
exgcd(p[1],p[i],a[i]-a[1],Y1,Yi);
add(a[1],mul(p[1],Y1,lcm),lcm),p[1]=lcm;
}
- 思想是合并方程组,现在假设我们要求解的是:
\]
- \(x\)是实际的值,显然有:
\]
是\(exgcd\)的形式,把\(y_0\)和\(y_i\)解出来。
此时$$p_0*y_0 = a_i-a_0\ \ \ mod \ p_i$$
所以让\(y_0\)对\(p_i\)取模,回代到$$x=p_0*y_0+a_0$$
此时\(x\)是在\(mod\ p_i*p_0\)意义下,取模后便是新的\(a_0\)了。
最后更新\(p_0\)
excrt就是把\(p_0*=p_i\)改成\(p_0=lcm(p_0,p_i)\)罢了。
BSGS
- 拔山盖世?
- 求
$$y^x≡z\ mod\ p$$
- 设\(x=i*m-j\),其中\(m=\sqrt p+1\)则
$$yj*z≡y{i*m}$$
枚举\(j\),把对应的\(y^j*z\)放在\(hash\)表里。或者也可以用\(map\)
注意这个时候的\(j\)要取最大值,从小往大枚举直接附值即可。
枚举\(i\),查对应的\(y^{i*m}\),如果有值,答案就是\(i*m-j\)了。
复杂度\(O(\sqrt p)\)
注意前提条件\(gcd(y, p) = 1\)
如果\(y\ mod\ p==0\),则无解。
\(upd\ on\ 11.7\)
首先有个模板题P4454 [CQOI2018]破解D-H协议
注意到
$$yj*z≡y{i*m}$$
- 这个东西中\(i*m-j\ge 0\)恒成立,所以在预处理时要\(j\)要从\(0\)开始到\(m\),但是查表的时候\(i\)要从\(1\)开始到\(m\)。
同余最短路
- 用一些数去拼凑出给定的数。
- 以最小值建立剩余系,令\(f_i\)表示在拼凑出长度\(mod\)最小值为\(i\)的最小花费。
- 显然每一个\(f_i\)都是这个剩余系中的最小值,且相互独立。
- 连边后做最短路即可。
- 不能拼凑出的最大值即位\(max(f_i-w_0)\),\(w_0\)是剩余系模数。
- [x] HDU 6071 Lazy Running
- 给出四个点1,2,3,4,1和2,2和3,3和4,4和1之间有路相连,现在从2点出发,最后回到2点,要求路径大于等于\(K\),问路径长度最短是多少,\(K\leq 10^{18},d\leq 3*10^4\)。
- 同余最短路套路了,取一条与\(2\)相连的权值最小的边\(w\)。
- 若存在一条从起点到终点的长度为k的路径,那么必然存在一条长度为\(k+2w\)的路径。
- 即只要一开始在那条边上往返走就好了。
- 设\(d_{i,j}\)表示从起点到\(i\),路径长度模\(2w\)为\(j\)时,路径长度的最小值。
- 然后\(dij\)预处理\(d\),最后枚举所有剩余系,如果大于等于\(K\)就恰好更新答案,否则补上剩下除以\(2*w\)向上取整数。
exgcd
- 求解\(a*x+b*y=c\)的最小特解。
- 注意在某些题目中要判断是否有解(裴蜀定理)。
- 设\(f=gcd(a,b,c)\),有一些题目中\(x=0\)要还原成\(b\),但是此时应该要还原成\(\frac {b}{gcd}\),这样才能保证最小正整解。
卢卡斯定理
- 处理计算组合时取模数特别小的时候,往往小于\(n,m\)。
- 对于质数而言,
\]
裴蜀定理
- \(a*x+b*y=c\)成立的充要条件是\(gcd(a,b)|c\).
组合计数
- 这不是计数里面的东西吗咕咕。
线性筛逆元
- 假设现在要求\(inv_i\),那么
- 有\(x*i+j=p\),此时\(j=p\ mod\ i\),\(x=\frac {p}{i}\)
- 在\(p\)剩余系下,那么\(inv_i=-1*x*inv_j\)
- 所以\(inv(i)=-inv(p\ mod\ i)*(p/i)\)
三分法
- 咕咕。
高斯消元
- 我采用的是高斯约旦消元法。
- 先找到系数最大的点提到当前行,然后消为\(1\),在把其他所有行的这一列消为\(0\)。
- 这样就省去了回带的过程。
- 无解情况:所有系数全为0但是值不为0
- 不唯一解情况:所有系数全为0值也为0
- 注意要先判断无解再判断解不唯一。
noip考前抱佛脚 数论小总结的更多相关文章
- NOIP考前划水
NOIP考前划水 君指先跃动の光は.私の一生不変の信仰に.唯私の超電磁砲永世生き! 要开始背配置了? 3行不谢. (setq c-default-style "awk") (glo ...
- Noip前的大抱佛脚----数论
目录 数论 知识点 Exgcd 逆元 gcd 欧拉函数\(\varphi(x)\) CRT&EXCRT BSGS&EXBSGS FFT/NTT/MTT/FWT 组合公式 斯特林数 卡塔 ...
- NOIP考前复习-数制转换,数论模板与文件读写
数制转换有两种题型,一般一题,分值1.5分. 题型一:R进制转十进制 解法就是:按权展开,但要注意各个位的权,最低位(最右边)的权是0次方,权值为1. 纯整数的情况: (11010110)2 = 1× ...
- 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; ...
- NOIP考纲总结+NOIP考前经验谈
首先来一张图,很直观(截止到2012年数据) 下面是收集的一些,我改了一下 红色加粗表示特别重要,必须掌握 绿色加粗表示最好掌握,可能性不是很大,但是某些可以提高程序效率 高精度 a.加法 b.减法 ...
- NOIP 考前研究
NOIP 2017 试题研究 D1T1 小凯的疑惑 (45 min) 看到题面,大概是推数学公式. 先打暴力表,观察 \(a,b\) 与 \(n\) 的关系.猜想 \(a×b−a−b\). 引理:对于 ...
- 【NOIP考前模拟赛】纯数学方法推导——旅行者问题
一.写在前面 这题似乎是一道原创题目(不是博主原创),所以并不能在任何OJ上评测,博主在网盘上上传了数据(网盘地址:http://pan.baidu.com/s/1mibdMXi),诸位看官需者自取. ...
- BZOJ4635 : 数论小测验
第一问: 设$a[i]$表示使用$[1,i]$的数字$n$次形成的数组里有多少个$\gcd=1$. 考虑容斥,则$a[i]=i^n-\sum_{j=2}^i a[\lfloor\frac{i}{j}\ ...
- 【学习整理】NOIP涉及的数论 [updating]
扩展欧几里得 求二元一次不定式方程 的一组解. int exgcd(int a,int b,int &x,int &y) { int t; ;y=;return a;} t=exgcd ...
随机推荐
- Python中的self用法之面向对象
class Student(object): def __init__(self, name, score): self.__name = name self.__score = score def ...
- 一、基础篇--1.1Java基础-抽象类和接口的区别
抽象类和接口的区别 抽象类和接口在设计层面的区别主要体现在:接口是对动作的抽象,抽象类是对根源.类的抽象.抽象类表示的是,这个对象是什么,接口表示的是,这个对象可以做什么. 比如,男人.女人是人,人是 ...
- 无人驾驶车辆路径跟踪的增量式PID控制
路径跟踪是无人车研究方向的一项关键技术.路径跟踪控制算法是指能够使无人车按照预设路径,安全稳定行驶的控制方法. 建立无人车路径跟踪模型 预设无人车在A.B两点间,当前位置为D点,航向为hF 可以得到B ...
- 关于加快INSERT语句执行速度和HINT /*+ append */及/*+ append nologging */的使用
(非归档模式下)创建表T01: SQL> create table t01 as select * from dba_objects where 1=2; Table created. (非归档 ...
- 微博获取原图时重定向到图片的url
微博获取原图时重定向到图片的url,所以获取的是乱码 jsoup默认是执行重定向的. //根据Url获取页面对应的Document public static Document getDoc1(Str ...
- python学习笔记:(六)str(字符串)常用方法
注意点: 1.字符串是不可变的: 2.%格式化操作符:左侧放置字符串,右侧放置希望被格式化的值. 对于单个字符的编码,Python提供了ord()函数获取字符的整数表示,chr()函数把编码转换为对应 ...
- C 语言中的预处理
C 语言中以 # 开头的就是预处理指令,例如 #include . 预处理指令的用途 所有的预处理指令都会在 GCC 编译过程的预处理步骤解析执行,替换为对应的内容.在下一步编译过程中,看不到任何预处 ...
- BigDecimal进行加减乘除计算
以前大部分关于查询计算的逻辑是在sql语句中执行的,但是有时候会出现比较复杂的计算情况,需要我们在代码中进行计算,这个时候使用BigDecimal进行计算会很方便. BigDecimal num1 = ...
- vue路由高级用法
五.路由设置高级用法alias 别名 {path:'/list',component:MyList,alias:'/lists'}redirect 重定向 {path:'/productList',r ...
- LeetCode算法题-Maximize Distance to Closest Person(Java实现)
这是悦乐书的第328次更新,第351篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第198题(顺位题号是849).在一排座位中,1表示一个人坐在该座位上,0表示座位是空的 ...