CDW数学小笔记
今天我们来做一道题目。
输入正整数\(n\)(\(\le 10^{15}\)),求\(x^2+y^2=n^2\)的整数解的个数。
也就是圆心为原点,半径为\(n\)的圆上整点的数量。
为了得到更普遍的结论,我们改为\(x^2+y^2=n\)来做。
我们引入一个概念,叫做
【定义1】高斯整数:形如\(a+bi\)的数称为高斯整数,其中\(a,b\in Z,i=\sqrt{-1}\)。
于是就转化为了求\((a+bi)(a-bi)=n\)中\(a,b\)的数量。
注意到\(n,a+bi,a-bi\)都是高斯整数,就联想到对高斯整数\(n\)进行质因数分解。
【定义2】高斯素数:高斯整数中,不能分解为两个高斯整数的乘积(\(1,-1,i,-i\)除外)的,称为高斯素数。
至于为什么\(1,-1,i,-i\)除外,就像整数分解中\(1,-1\)除外一样,因为这些东西是单位元,对分解形式没有什么大的影响,所以就去除了。
如何对整数\(n\)进行高斯素数的分解呢?注意到\(n=p_1p_2\ldots p_k\)有唯一分解形式,只要考虑质数\(p\)如何进行高斯素数的分解。于是就有了
【定理1】(费马二平方和定理) 对于质数\(p\),若\(p\equiv 1(\mathrm{mod} \ 4)\)或\(p=2\),则\(x^2+y^2=p\)有一个正整数解;若\(p\equiv 3(\mathrm{mod} 4)\),则\(x^2+y^2=p\)无正整数解。
举个栗子,\(5=(2+i)(2-i),17=(4+i)(4-i),13=(3+2i)(3-2i)\),而\(3,7,31\)这些素数无法分为两个共轭的高斯整数的乘积。
(这个定理的证明被鸽掉了,大家当结论用吧)
也就是说,\(25=5^2=(2+i)(2-i)(2+i)(2-i)\),那么如何计算\(25=(a+bi)(a-bi)\)的解的数量呢?我们把质因子分为两个元素个数相等的可重集合\(A,B\),其中满足\(z\in A\Rightarrow \bar{z}\in B\),也就是\(A,B\)中的元素对应互相共轭,则令\(Z=\prod_{z\in A}z\),则\(\bar{Z}=\prod_{z\in A}\bar{z}=\prod_{z\in B}z\),所以\(n=Z\times \bar{Z}\),令\(a+bi=Z\)即可。
也就是说一种\(A,B\)的分配方法对应了一组整数解,注意到如果\(A\)中有\(a\)个\(2+i\),那么\(B\)中有\(2-a\)个\(2+i\),有\(a\)个\(2-i\),\(A\)中有\(2-a\)个\(2+i\),所以共有3组整数解。。。
吗?
枚举一下就发现实际上是\(12\)组整数解,因为上面我们将\(1,-1,i,-i\)除去了,实际上我们可以对其中一个数乘上\(1,-1,i,-i\),另一个数对应地乘上\(1,-1,-i,i\),于是还应该乘上4倍。
再来看看\(75=3*5^2=3(2+i)(2-i)\),发现无论\(3\)放到哪里都是不行的,因为对面也要有一个\(3\)。所以\(x^2+y^2=75\)没有整数解。
再来看看\(50=2*5^2=(1+i)(1-i)(2+i)(2-i)\),根据刚才的计算方法,我们可以在左边放\(a\)个\(1+i\),\(b\)个\(2+i\),其中\(0\le a,b\le 1\),则有\(4\)种,再乘上\(4\)就是\(16\)个整数解。。。
吗?
枚举一下就发现实际上是\(8\)组整数解,因为上面我们要乘上\(4\)是因为可以对其中的数乘上\(1,-1,i,-i\),但是我们发现\(1+i=i(1-i)\),所以\(1+i\)和\(1-i\)放在哪里并没有关系,所以\(n\)中\(2\)的质因子个数对答案没有影响。应该忽略就可以了。
现在我们总结一下\(n=2^ap_1^{a_1}p_2^{a_2}\ldots p_k^{a_k}\),则根据上面的讨论,\(2^a\)对答案没有贡献,如果\(p_i\equiv 1(\mathrm{mod} \ 4)\)则对答案有\(a_i+1\)的贡献,如果\(p_i\equiv 3(\mathrm{mod} \ 4)\),若\(2|a_i\)则对答案没有贡献,否则对答案有\(0\)的贡献(无解),乘起来得到的再乘上\(4\)就是最后答案。
现在我们已经能做出来这道题了,对\(n^2\)进行质因数分解,然后直接套公式就可以做出来了。
众所周知,与圆周率\(\pi\)有关的有一堆的公式,我们今天算的是圆上的整点个数,所以我们讨论一下它和\(\pi\)的关系。
注意到半径为\(R\)的圆面积\(\pi R^2\)近似于内部的整点个数,我们用这个来计算\(\pi\),而且\(R\)越大算的就越精确(误差是\(O(R)\)级别而面积是\(O(R^2)\)级别的)。
虽然上面的结论已经非常简洁了,但是做这道题我们还需要再进行简化一下。我们引入
【定义3】我们定义数论函数\(\chi(n)\),其中
\[
\chi(n)=\begin{cases}1 & (n\equiv 1(\mathrm{mod} \ 4)) \\ -1 & (n\equiv 3(\mathrm{mod} \ 4)) \\ 0 & (2|n)\end{cases}
\]
所以\(\chi(n)\)是一个完全积性函数,而且
\[
\begin{aligned}
\chi(1)+\chi(5)+\chi(5^2)+\chi(5^3)&=4 \\
\chi(1)+\chi(3)+\chi(3^2)+\chi(3^3)&=0 \\
\chi(1)+\chi(3)+\chi(3^2)+\chi(3^3)+\chi(3^4)&=1 \\
\chi(1)+\chi(2)+\chi(2^2)+\chi(2^3)&=1
\end{aligned}
\]
整明白点儿啥没?
\(x^2+y^2=n\)的整数解的数量(除以4)为
\[
\begin{aligned}
&(\chi(1)+\chi(p_1)+\chi(p_1^2)+\ldots+\chi(p_1^{a_1}))\times \\
&(\chi(1)+\chi(p_2)+\chi(p_2^2)+\ldots+\chi(p_2^{a_2}))\times \\
&\ldots \\
&(\chi(1)+\chi(p_k)+\chi(p_k^2)+\ldots+\chi(p_k^{a_k})) \\
=&\sum_{0\le b_i\le a_i}\prod_{i=1}^k\chi(p_i^{b_i}) \\
=&\sum_{0\le b_i\le a_i}\chi(\prod_{i=1}^k p_i^{b_i}) \\
=&\sum_{d|n}\chi(d)
\end{aligned}
\]
【定理2】\(x^2+y^2=n\)的整数解的数量为\(4\sum_{d|n}\chi(d)\)。
圆内整点的数量实际上就是同心且比它小的所有圆经过的整点数量,我们设\(R^2=n\)。
\[
\begin{aligned}
\frac{\pi}{4}&=\lim_{n\rightarrow +\infty}\frac{\sum_{i=1}^{n}\sum_{d|i}\chi(d)}{n} \\
&=\lim_{n\rightarrow +\infty}\frac{\sum_{d=1}^n\chi(d)\frac{n}{d}}{n} \\
&=\lim_{n\rightarrow +\infty}\sum_{d=1}^n\frac{\chi(d)}{d} \\
&=1-\frac{1}{3}+\frac{1}{5}-\frac{1}{7}+\frac{1}{9}-\frac{1}{11}+\ldots
\end{aligned}
\]
整明白点儿啥没?
CDW数学小笔记的更多相关文章
- 转:【iOS开发每日小笔记(十一)】iOS8更新留下的“坑” NSAttributedString设置下划线 NSUnderlineStyleAttributeName 属性必须为NSNumber
http://www.bubuko.com/infodetail-382485.html 标签:des class style 代码 html 使用 问题 文件 数据 ...
- 小笔记:Timer定时间隔时间操作
小笔记:Timer定时间隔时间操作,后面有时间再补充和完善: public class TimingSvc { /// <summary> /// 定时器,执行定时任务 /// </ ...
- 关于 linux中TCP数据包(SKB)序列号的小笔记
关于 SKB序列号的小笔记 为了修改TCP协议,现在遇到了要改动tcp分组的序列号,但是只是在tcp_sendmsg函数中找到了SKB的end_seq 一直没有找到seq 不清楚在那里初始化了,就 ...
- Linux下postgres9.4 版本的单机版安装小笔记
1.添加RPMyum install https://download.postgresql.org/pub/repos/yum/9.4/redhat/rhel-7-x86_64/pgdg-redha ...
- php的一些小笔记--数学函数
通常我们使用的数学函数不多,经常出现的有 floor 地板->舍去 ceil 天花板->进一 round 四舍五入 rand 随机数 mt_rand 产生更好的随机数 pow 指数表达 ...
- 深入剖析Nginx一点小笔记
前几天在图书馆看书,恰好看到这本<深入剖析nginx>,花了快一周的时间看完了这本书,写点笔记心得便于以后复习. 以前对nginx的认识就只是停留在一个反向代理服务器上.百度了一下ngin ...
- 3D数学学习笔记——笛卡尔坐标系
本系列文章由birdlove1987编写.转载请注明出处. 文章链接: http://blog.csdn.net/zhurui_idea/article/details/24601215 1.3D数学 ...
- 3D数学读书笔记——3D中的方位与角位移
本系列文章由birdlove1987编写,转载请注明出处. 文章链接: http://blog.csdn.net/zhurui_idea/article/details/25339595 方位和角位移 ...
- # ML学习小笔记—Gradien Descent
关于本课程的相关资料http://speech.ee.ntu.edu.tw/~tlkagk/courses_ML17.html 根据前面所为,当我们得到Loss方程的时候,我们希望求得最优的Loss方 ...
随机推荐
- Git和Github的介绍、简单操作、冲突(上)
目的: 1.git与github简介 2.Git与SVN区别 3.Github 的简单使用 4.下载安装Git-20-64-bit.exe 5.Git常用命令 5.1Git命令使用场景 5. ...
- Vector、ArrayList异同和HTTP请求异同的概括和区别
今天我所记录的是两个异同的概括: HTTP: 同步请求:提交请求->等待服务器处理->处理完毕返回给客户端 这个期间客户端浏览器只能处于等待状态,得到回应才可以执行下一步操作. 异步请求 ...
- jmeter命令行执行脚本_动态参数设置
从04月换公司开始,就没静下来心来学习,其中发生了比较多的事情吧,不过不管如何,没坚持学习还是因为懒.本周交接完,下周去入职新公司,该静下心来学点什么了. ---------------------- ...
- Python 内置函数进制转换的用法(十进制转二进制、八进制、十六进制)
使用Python内置函数:bin().oct().int().hex()可实现进制转换. 先看Python官方文档中对这几个内置函数的描述: bin(x)Convert an integer numb ...
- GIL与线程进程小知识点
一 .GIL全局解释器 GIL是一个互斥锁:保证数据的安全(以牺牲效率来换取数据的安全)阻止同一个进程内多个线程同时执行(不能并行但是能够实现并发)并发:看起来像同时进行的GIL全局解释器存在的原因是 ...
- git一些简单运用
1.删除本地文件后,继续从远处仓库拉取回来,提示up-to-date,执行如下 git reset --hard origin/master 待补充
- Android 在同一台设备上安装多个同一项目的apk
如果设备上已经安装了一个apk,再次安装这个apk就会提示覆盖前面的应用 解决办法: 方法一:手动改包名 不好改,改了几次都不成功(可能是代码在svn管理的原因,改完后文件夹里的代码就没了),确实不实 ...
- 解决 React Native:The development server returned response error code: 404
解决方法: 打开android/app/build.gradle compile 'com.facebook.react:react-native:+' 修改为: compile ("com ...
- 基于beautifulSoup进行电影网站排名的获取与格式化输出
要求 编写代码完成以下任务: ① 将地址"http://www.cbooo.cn/year?year=2019"源代码使用任意方法保存到指定文件中(文件类型不限). ② 使用文件流 ...
- PAT基础级-钻石段位样卷2-7-3 大笨钟 (10 分)
微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉.不过由于笨钟自己作息也不是很规律,所以敲钟并不定时.一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那 ...