TAT快noip了才开始去接触数论(真心不敢学。。)这里做一下整理吧(都是些定义之类的东西= =)

欧几里德:gcd(a,b)=gcd(b,a%b);具体证明见百科?

扩展欧几里德:

  求a*x+b*y=gcd(a,b);

  因为gcd(a,b)=gcd(b,a%b)即gcd(b,a-a/b*b);

  所以可以递归求解:

    递归到b=0时显然gcd为a,x=1,y=0;

    已知b*x'+(a-a/b*b)*y'=gcd(b,a-b/b*b)=gcd(a,b)=a*x+b*y;

    b*x'+(a-a/b*b)*y' = a*y'+b*(x'-a/b*y');

    所以x=y';y=x'-a/b*y';

  然后解显然不只一个。。设我们一开始求出来的解为x0,y0

  x = x0 + b/Gcd(a, b) * k
    y = y0 -  a/Gcd(a, b) * k(k为任意整数)(代入一下就知道正确性了。。)

  有的时候(似乎很多时候?)gcd(a,b)=1.....

  各种低级应用:

  不定方程向:

    求x,y,使a*x+b*y=c;(只有c为gcd(a,b)的倍数时才有解)

    解就是a*x+b*y=gcd(a,b)的每个解乘上c/gcd(a,b)。。或者说是a/gcd(a,b)*x+b/gcd(a,b)=1的每个解乘上c

   解模线性方程(最基本的同余方程)ax ≡ b(mod p)

    因为a*x mod p实际就是a*x-a*x/p*p..所以等价于解不定方程 a*x+p*y=b

  乘法逆元向:
    满足b*k≡1 (mod p)的k值就是b关于p的乘法逆元。
    应用:
      求(a/b) mod p的值时,a过大等等感人情况(比如求模意义下较大的组合数或者卡特兰数或者是奇怪的数学题?)
      求b关于p的乘法逆元k,(a*k) mod p的结果与(a/b) mod p等价
    证明:

      已求出b*k≡1(mod p);
      即b*k=p*x+1;

      所以k=(p*x+1)/b;
      a*k=a/b*(p*x+1)
      (a*k) mod p

       =(a/b*(p*x+1))mod p
       =(a/b*p*x+a/b)mod p
       =(a/b)mod p

    求逆元:

      a*k≡1(mod p)即a*k=p*x+1
      相当于解不定方程a*k-p*x=1(a,p已知)

素数线性筛:

  万年大坑现在才来填QAQ。。虽然以前用埃氏筛法似乎姿势好可以混过去?

  埃氏筛法的缺点是合数可能会被多次筛到(取决于它有多少个质因数)

  现在对于每个数i,

  1、若i为素数,枚举不大于i的素数j,则i*j为合数(此时不可能有重复)
  2、 i为合数,则设i=p1^a1*p1*a2*p3^a3。。。。(整数分解)
  枚举所有小于或等于p1的素数j,i*j为合数
  不会重复计算是因为每个数都是被它的最小质因数筛到的

欧拉函数线性筛:
  设a为n的某个质因数,
  1、若n/a整除a,则phi(n)=phi(n/a)*a(每个与n/a互质的数也与a互质)
  2、 若n/a不整除a,则phi(n)=phi(n/a)*(a-1)(因为a是素数,phi(a)=a-1,gcd(a,n/a)=1,由欧拉函数的积性phi(n)=phi(n/a)*phi(a)......)

感觉今年noip考数论的话我就得直接退役了QAQ

UPD:2333今年没数论。。然而还是不会写的题还是不会TAT

noip级别数论?的更多相关文章

  1. noip级别模板小复习

    不是很noip的知识点就不写了. dij什么的太easy就不写了. 缩点 注意\(Tarjan\)在缩边双和求强联通分量时候的区别. 一个要判断是否在栈内一个不要. 最后\(topsort\)来\(d ...

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

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

  3. 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; ...

  4. [总结] NOIP 前的考试记录

    sb博主又犯sb错误了! 他觉得以往模拟赛因为犯sb错误扔的分足足有1k分了! 于是他想记录一下自己犯的sb错误看看自己到底有多sb! 嗯就从今天开始吧 2018.9.28 1. 二分边界写错.骚什么 ...

  5. 6.19 noip模拟题(题目及解析转自 hzwer 2014-3-15 NOIP模拟赛)

    Problem 1 高级打字机(type.cpp/c/pas) [题目描述] 早苗入手了最新的高级打字机.最新款自然有着与以往不同的功能,那就是它具备撤销功能,厉害吧. 请为这种高级打字机设计一个程序 ...

  6. NOIP 2018 -The Wound-

    "一招不慎,满盘皆输" 如果这个盘是整整一年的OI生涯的话 那么"一招"一定就是NOIP了 Update 2019/4/6 剧变的一年 noip这个成绩意味着我 ...

  7. 2016-06-19 NOIP模拟赛

          2016-06-19 NOIP模拟赛 by coolyangzc 共3道题目,时间3小时 题目名 高级打字机 不等数列 经营与开发 源文件 type.cpp/c/pas num.cpp/c ...

  8. NOIp 数学知识点总结

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

  9. Noip2018退役记。

    下面是边考试边写的严肃版退役记\(:D\) Day0 其实我本来想取个这个名字:\(NOIP2018\)提高组复赛试题解析 但是这个博客自己求生欲望太强自己改名了. 先占个坑. noip考前毒奶 \( ...

随机推荐

  1. ionic环境配置及问题

    ionic是什么? 其实就是一款用于开发web app的开源免费框架,和国产的MUI差不多. 官网:https://ionicframework.com/ 必备条件: 安装Node.js 安装Java ...

  2. RabbitMQ 1-入门学习

    环境: 软件环境MacOS ,Homebrew包管理工具 IDE: Eclipse 项目:Maven项目 1.安装RabbitMQ Server: 方式一:通过homebrew :终端执行:brew ...

  3. css弹性盒子新旧兼容

    前言:本篇随笔是对弹性盒子有了解的人来写的这篇文章,具体属性产生的效果这里不做说明,基础的东西去查文档.这里只是总结. 时至今日,css3的flex弹性盒子在移动端基本上都是支持的,但不排除有些些低版 ...

  4. 3.sass的数据类型与函数

    数据类型 在sass里有数字.字符串.列表.颜色等类型 在cmd里 输入 sass -i 就会进入到交互模式,输入的计算可以马上得到结果 type-of()可以用来得到数据类型,如: type-of( ...

  5. python:发送消息给微信企业号

    # -*- coding:utf-8 -*- import requests import json ''' 基础环境:微信企业号 version:python 2.7 ''' class Send_ ...

  6. python爬取大众点评并写入mongodb数据库和redis数据库

    抓取大众点评首页左侧信息,如图: 我们要实现把中文名字都存到mongodb,而每个链接存入redis数据库. 因为将数据存到mongodb时每一个信息都会有一个对应的id,那样就方便我们存入redis ...

  7. 使用 mysql PDO 防止sql注入

    技巧: 1. php升级到5.3.6+,生产环境强烈建议升级到php 5.3.9+ php 5.4+,php 5.3.8存在致命的hash碰撞漏洞. 2. 若使用php 5.3.6+, 请在在PDO的 ...

  8. python pandas stack和unstack函数

    在用pandas进行数据重排时,经常用到stack和unstack两个函数.stack的意思是堆叠,堆积,unstack即"不要堆叠",我对两个函数是这样理解和区分的. 常见的数据 ...

  9. LeetCode题目总结(二)

    我的代码在github上,https://github.com/WINTERFELLS/LeetCode-Answers 这里只提供个人的解题思路,不一定是最好的. Problems 21-40 合并 ...

  10. Python新式类与经典类的区别

    1.新式类与经典类 在Python 2及以前的版本中,由任意内置类型派生出的类(只要一个内置类型位于类树的某个位置),都属于“新式类”,都会获得所有“新式类”的特性:反之,即不由任意内置类型派生出的类 ...