首页 > 代码库 > 勾股数组 学习笔记

勾股数组 学习笔记

颓废了一个暑假,想做点CF提高一下智商,然后就被这题卡住了。    http://codeforces.com/contest/707/problem/C

题目大意是给出各条边都是正整数的直角三角形的一条边长,求另外两条边可能的一种方案。 除了爆搜脑子一片空白,然后就很没志气的看了题解,提到了勾股数组,于是学习了一下.网络上的资料感觉证明不是详细,所以自己来写个总结。


 

1.首先如果 $a^2+b^2=c^2$ , 则$(ka)^2+(kb)^2=(kc)^2$ , 因此我们先只考虑$gcd(a,b,c)=1$的情况.

2.$a$和$b$必定一个是奇数一个是偶数.

   反证: 如果a,b都是偶数,那么c也为偶数,则$gcd(a,b,c)$不可能为1.  如果a,b都是奇数,那么c为偶数.   $a^2+b^2 \equiv\ 2 (mod\ 4)$. 而$c^2 \equiv\ 0 (mod\ 4)$ .

3.不妨设$a$为偶数,那么$b$,$c$都是奇数。  设$a=2mn$ $(m>n)$. 下面证明$(a,b,c)$可以表示为$(2mn,m^2-n^2,m^2+n^2)$的形式。  反解$m,n$可以得到

$m=\sqrt{\frac{b+a}{2}}$    $n=\sqrt{\frac{c-b}{2}}$ .  

只需证明$\sqrt{\frac{b+a}{2}}$和$\sqrt{\frac{b-a}{2}}$都是正整数,即证明$\frac{b+a}{2}$和$\frac{b+a}{2}$都是完全平方数。

$a^2=c^2-b^2=(c-b)*(c+b)$.

先证明$gcd(c-b,c+b)=2$ :

 $$d|c+b,d|c-b\ \to\ \ d|2b,d|2c\ \ \to\ \ d|gcd(2b,2c)\ \ \to\ \ d|2gcd(b,c)\ \ \to\ \ gcd(c+b,c-b)|2$$

而$b$,$c$均为偶数,那么$c-b$,$c+b$也都是偶数,那么$gcd(c-b,c+b)$只能是2.  所以有$gcd(\frac{c-b}{2},\frac{c+b}{2})=1$

因为$(\frac{a}{2})^2=\frac{c-b}{2}*\frac{c-b}{2}$  且$gcd(\frac{c-b}{2},\frac{c+b}{2})=1$,所以$\frac{c-b}{2}$和$\frac{c+b}{2}$都是完全平方数。

故$(a,b,c)$可以表示为$(2mn,m^2-n^2,m^2+n^2)$的形式,只需取$m=\sqrt{\frac{b+a}{2}}$    $n=\sqrt{\frac{c-b}{2}}$ . 

这就给出了构造勾股数组的一个公式,因为$(m,n)$和$(a,b,c)$存在一一对应的关系。 同理$(km,kn)$和$(ka,kb,kc)$也对应,因此这个公式也适用于$gcd(a,b,c)>1$的情况。

 


 

 

再回到最开始的CF的那道题。

1.如果一开始给的数<=2,那么肯定无解,因为不存在一个勾股数组里面有元素<3.

证明:不妨设$a<=b<c$, 因为$a^2=(c-b)*(c+b)$    $(c+b)-(c-b)=2b>=2$  如果$a<=2$ 那么$a^2=(c-b)*(c+b)<=4$  容易检验无解。

2.如果一开始给了一个偶数$a$,那么$a=2mn$ 令$n=1,m=\frac{a}{2}$即可构造出一组$(a,b,c)$.

3.如果一开始给了一个奇数$b$,那么$b=m^2-n^2=(m+n)*(m-n)$ 令$m-n=1,m+n=b$ 解出$m$和$n$ 就可以得到一组$a$和$c$了.   

ps:构造方法有很多,可以百度一下,这只是我自己想到的一种。

 


bonus:如果把上面那题升级成求方案数该怎么办?

1.如果一开始给的数<=2,那么肯定无解,因为不存在一个勾股数组里面有元素<3.

2.如果一开始给了一个偶数$a$,那么$a=2mn$ 因为$(m,n)$和$(a,b,c)$存在一一对应的关系,只需求出$a$可以分解成多少种$(m,n)$。通过求$\frac{a}{2}$的因子个数容易得到答案。

3.如果一开始给了一个奇数$b$,那么$b=m^2-n^2=(m+n)*(m-n)$ 只需求出$b$可以分解成多少种$(m+n,m-n)$ 通过求出b的因子个数容易得到答案。

 

 

现学了点用latex表示数学公式的语法,就拿这篇博文做做练习. 马上要去上大学啦,给自己加个油,大学里一定要继续努力。

 

勾股数组 学习笔记