清北学堂学习总结day2
今天是钟皓曦大佬讲课,先来膜一波 %%%%%
•数论
数论是这次培训的一个重点,那么什么是数论呢?
数论是研究整数性质的东西,所以理论上day2不会涉及小数QwQ
(切入正题)
•整除性:
设a,b ∈ Z,如果
c ∈ Z 并且 a = b * c,则称 b | a
称:
b为a的因子
b能整除a
a能被b整除 / /好像很简单的样子
•质数:
只有1和自身作为因子的数叫做质数
以 π(x)表示不超过x的素数个数,可以证明出以下结论(1):
lim π(x) * ln x / x = 1;
也就是 lim π(x) = x / ln x;
这个结论对于分析算法复杂度有一定帮助;
结论(2):(欧几里得引理)
设p为质数,若 p | a * b ,则 p | a 或者 p | b。
这个结论是一个基础结论,广泛用于以下结论的证明;
•整数分解定理----算数基本定理:
对于任意大于1的正整数N,N一定能够分解成有限个质数的乘积和,即:
N = p1a1 * p2a2 * ...... pkak
其中p1<p2<......<pk,a1、a2、a3、...... 、ak均为正整数;
下面给出证明:
首先证明存在性:
我们可以用反证法,设N为不满足条件的最小的数,N如果是质数就不符合条件(N1),如果N不是质数还是不符合条件(根据对合数的定义,以及一个叫数学归纳法的玩意儿),证毕;
再来证明唯一性:
这里就用到了欧几里得引理,也就是上文所说的 “ 广泛用于以下结论的证明 ” 的结论,我也没有打自己脸
假设n为不能被分为质数的乘积的自然数之一,且n为最小
因为设n为大于1的合数(如果n为质数,则只有n=n,显然这是质数的乘积)
因为每个合数都可以分为两个大于1小于它的两自然数的乘积
所以n=a×b
又因为n为不能被分为质数的乘积的自然数中最小的一个
所以a和b可以分为质数的乘积
所以n已就可以分为质数的乘积,与假设不符合,故假设错误
存在性得证。
•筛素数(这里先不展开讲,有兴趣可以参考我的博文,应该会在一两天内出炉)
•最大公因数:
英文缩写:gcd
它的定义是:gcd ( a , b ) = max { x ( x | a , x | b ) }
既然讲到了最大公约数,就不得不讲讲欧几里得算法啦,就当是自己复习一下了;
欧几里得算法的核心思想,就是把gcd(a,b)转化为gcd(b,a % b)
下面是证明:
将a的带余除法式写出来:a = k * b + r(其中a,b,k,r皆为正整数,且r<b),则r = a % b
假设d是a , b的一个公约数,记作d | a,d | b,即a和b均可以被d整除,而r = a - k * b,两边同时除以d,r / d = a / d - k * b / d = m,由等式右边可知m为整数,因此d | r,因此d也是b,a%b的公约数。
下面再证d是最大的,假设d是b , a % b的公约数, 则d | b , d | ( a - k * b ) , k 是一个整数。进而d | a(结合上面的证明).因此d也是a , b的公约数,因此( a , b )和( b , a % b )的公约数是一样的,其最大公约数也必然相等,得证。
接下来就是最最激动人心的代码实现啦
#include<cstdio>
#include<iostream>
#include<cstdlib>
using namespace std;
int gcd(int,int);
int main()
{
int a,b;
scanf("%d%d",&a,&b);
printf("%d",gcd(a,b));
return ;
} int gcd(int a,int b)
{ if(a<b) return gcd(b,a); //对a<b时的特判;
if(b==) return a;
else return gcd(b,a%b);
}
•裴蜀定理:
给定a,b,c,则ax + by = c有整数解的充要条件为gcd(a,b) | c
辣么我们证一下
根据唯一分解定理,可以很简单的得出,但如果我们不用呢?
先来证必要性:
a = a'd , b = b'd
ax + by = ( a'x + b'y )d = c
得证!
接下来是充分性:
我们可以转化成证明d是最小的能写成ax + by的正整数,设ax + by能表示的最小正整数为s,
a / s = q……r , r = a - qs = a - q ( ax + by ) = a ( 1 - qx ) + b ( -qy ) , 0<=r<s => r = 0 => s | d
又因为d | ax + by = ( a'x + b'y )d => d | s
所以d = s
那么我们就可以证明欧几里得引理啦:
若p | a,搞定!
否则有gcd( p , a ) = 1 , 则
n , m使得np + ma = 1.所以b = b ( np + ma ) = bnp + mba = bnp + mtp
得证!
•扩展欧几里得(exgcd)
•中国剩余定理
•逆元
如果(a,m) = 1且存在唯一的b使得a * b ≡ 1(mod m)且1 ≤ b < m,则b为a在模m意义下的逆元;
这里再介绍2个结论:
结论(1):(费马小定理)
ap-1 ≡ 1
结论(2):(欧拉定理)
aΦ(m) ≡ 1
欧拉定理的证明不再阐述,有兴趣可以参考百度。
清北学堂学习总结day2的更多相关文章
- 清北学堂学习总结 day2 字符串 练习
1.hash表(哈希表) codevs 2147 数星星--简单哈希 时间限制: 3 s 空间限制: 64000 KB 题目等级 : 钻石 Diamond 题目描述 Description 小明 ...
- 清北学堂学习总结day3
小学知识总结 上午篇 •积性函数的卷积公式 (1)(f * g)( n ) = ∑(d|n) f( d ) x g ( n / d ) (2)代码实现 LL f[N], g[N], h[N]; voi ...
- 清北学堂学习总结day1
上午篇 一.高精度计算: [以下内容先只考虑非负数情况] •高精度加法: 思路:[模拟竖式运算] 注意:[进位] •高精度减法: 思路:[同加法类似,模拟竖式运算,进位变退位] 注意: [结果为负数的 ...
- 清北学堂学习总结 day1 数据结构 练习
1.二叉搜索树 STL set直接做就可以了 2.树状数组+差分数列: codevs 1081 线段树练习 2 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Maste ...
- 清北学堂2017NOIP冬令营入学测试P4745 B’s problem(b)
清北学堂2017NOIP冬令营入学测试 P4745 B's problem(b) 时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试 描述 题目描 ...
- 清北学堂2017NOIP冬令营入学测试 P4744 A’s problem(a)
清北学堂2017NOIP冬令营入学测试 P4744 A's problem(a) 时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试题,每三天结算 ...
- 济南清北学堂游记 Day 1.
快住手!这根本不是暴力! 刷了一整天的题就是了..上午三道题的画风还算挺正常,估计是第一天,给点水题做做算了.. rqy大佬AK了上午的比赛! 当时我t2暴力写挂,还以为需要用啥奇怪的算法,后来发现, ...
- 清明培训 清北学堂 DAY1
今天是李昊老师的讲授~~ 总结了一下今天的内容: 1.高精度算法 (1) 高精度加法 思路:模拟竖式运算 注意:进位 优化:压位 程序代码: #include<iostream>#in ...
- 7月清北学堂培训 Day 3
今天是丁明朔老师的讲授~ 数据结构 绪论 下面是天天见的: 栈,队列: 堆: 并查集: 树状数组: 线段树: 平衡树: 下面是不常见的: 主席树: 树链剖分: 树套树: 下面是清北学堂课程表里的: S ...
随机推荐
- 如何在本地编译Fabric Code
之前的博客都是拿官方现成的Docker镜像来用,但是并没有自己动手做镜像,也没有说到如何去开发和测试Fabric的代码.这一篇博客就从入门的角度讲解如何编译.测试和开发Fabric. 一.环境准备 要 ...
- 超链接标签绑定JS事件&&不加"javascript:;"导致的杯具
很久以来,在写Html和JS时,经常会给超链接<a>标签,绑定JS事件. 我们经常看到这样的写法,<a href="javascript:;" onclick=& ...
- openstack第六章:dashboard
第六篇horizon— Web管理界面 一.horizon 介绍: 理解 horizon Horizon 为 Openstack 提供一个 WEB 前端的管理界面 (UI 服务 )通过 ...
- Ubuntu下找不到ttyUSB*问题解决
一.硬件连接 确认Ubuntu对USB转串口设备的支持. 1.# lsmod | grep usbserial如果有usbserial,说明系统支持USB转串口. 如果没有,先安装ch340驱动或者c ...
- 利用node.js来实现长连接/聊天(通讯实例)
首先: 需要在服务器端安装node.js,然后安装express,socket.io这两个模块,并配置好相关的环境变量等. 其次: 服务端代码如下: var app = require('expres ...
- pytorch识别CIFAR10:训练ResNet-34(准确率80%)
版权声明:本文为博主原创文章,欢迎转载,并请注明出处.联系方式:460356155@qq.com CNN的层数越多,能够提取到的特征越丰富,但是简单地增加卷积层数,训练时会导致梯度弥散或梯度爆炸. 何 ...
- flutter 返回键监听
本篇为继上片监听返回键基础下优化: 以下做返回键监听两种情况: import 'package:fluttertoast/fluttertoast.dart'; //提示第三方插件 1. 单击提示双击 ...
- Git 本地保存账号密码的删除或修改
转自:https://blog.csdn.net/lwqldsyzx/article/details/61228299 Git 本地拉取代码时需要输入用户名和密码时,会自动将用户名密码信息保存起来.需 ...
- 浅析Java数据类型
前言: 该系列会辅以MindMap进行说明. 下面会贴两张我不同时期画的Java数据类型的思维导图,本篇主要侧重于Java的8种基本类型 MindMap-1 这张MindMap主要是根据 菜鸟教程+参 ...
- React Native动画总结
最近在使用react native进行App混合开发,相对于H5的开发,RN所提供的样式表较少,RN中不能使用类似于css3中的动画,因此,RN提供了Animated的API 1.写一个最简单的动画 ...