由熟知的勾股定理 (Pythagorean theorem), 直角三角形的三边长 `a, b, c` 满足 `a^2+b^2=c^2`. 我们称满足上述不定方程的正整数 `a, b, c` 为一组勾股数 (Pythagorean triple), 如 `3, 4, 5`; `5, 12, 13`; `7, 24, 25` 等. 以勾股数为边长的直角三角形叫勾股三角形. 注意到像 `3, 4, 5` 与 `6, 8, 10` 是本质相同的勾股数, 故定义勾股数 `a, b, c` 是本原的, 如果 `gcd(a, b, c) = 1`.
本原勾股数 `a, b, c` 两两互素, 且 `c` 为奇数, `a, b` 一奇一偶.
设 `d = (a, b)`, 则 `d^2 | a^2 + b^2 = c^2`, 这推出 `d | c`.
于是 `d | (a, b, c) = 1`, 即 `d = 1`. 同理 `(b, c) = (c, a) = 1`.
因为 `(a, b, c)` 两两互素, 它们中的偶数不超过一个, 假设 `c` 为偶数,
则 `a, b` 为奇数. 设
`a = 2m+1`, `quad b = 2n+1`, `quad c = 2k`,
则 `a^2 + b^2 -= 2 (mod 4)`, `c^2 -= 0 (mod 4)`, 矛盾.
因此 `c` 为奇数. 注意到 `a, b` 不全为偶数, 其中一个为奇数,
则另一个为偶数.
由于 `a, b` 地位对称, 不妨设 `b` 是偶数, 则本原勾股数的全体可以表示为 `a = u^2-v^2`, `quad b = 2u v`, `quad c = u^2+v^2`. 其中 `u gt v gt 0`, `quad (u, v) = 1`, 且 `u, v` 一奇一偶.
容易说明满足上述条件的 `(a, b, c)` 确实是本原勾股数. 下证必要性.
注意 `c-a, c+a, b` 都是正的偶数, 可设
`2A = c-a`, `quad 2B = b`, `quad 2C = c+a`,
`A, B, C` 为正整数. 因为 `b^2 = c^2 - a^2 = (c-a)(c+a)`, 我们有
`B^2 = A C`.
下证 `A, C` 互素. 设 `d = (A, C)`, 则
`d | C-A = a`, `quad d | C+A = c`,
从而 `d | (a, c) = 1`, 即 `d = 1`.
因为 `A C` 是平方数, 而 `A, C` 没有公共的素因子, 所以 `A, C`
都是平方数, 可设
`C = u^2`, `quad A = v^2`.
于是
`a = u^2-v^2`, `quad c = u^2+v^2`,
`b = 2 sqrt(B^2)`
`= 2 sqrt(A C)`
`= 2 u v`.
最后说明 `u, v` 满足的条件. 由 `C gt A` 有 `u gt v gt 0`.
由 `(A, C) = 1` 知 `(u, v) = 1`. 由 `a = u^2 - v^2` 是奇数知 `u, v`
一奇一偶.
可以用代数计算验证, 确实有 `(u^2-v^2)^2 + (2u v)^2 = (u^2+v^2)^2`. 由以上讨论知, 任意一个勾股三角形总是相似于边长为 `u^2-v^2, 2u v, u^2+v^2` 的三角形, 其中 `u gt v gt 0`. 代入 `(u,v) = (2,1)` 得到勾股数 `(3, 4, 5)`, 代入 `(u,v) = (3,2)` 得到勾股数 `(5,12,13)`... 试试看吧!
[来自讲义《MIT18: Rational Points on Conics》]
将寻找勾股数的问题转化为单位圆上的有理点, 这个方法可以推广到一般的圆锥曲线. 具体来说, 齐次不定方程 `a x^2 + b x y + c y^2 + d x z + e y z + f z^2 = 0` 满足 `z != 0` 的解可以转化为寻找整系数圆锥曲线 `a x^2 + b x y + c y^2 + d x + e y + f = 0` 上的有理点. 假设 `(x_0, y_0)` 是曲线上的一个有理点, 过该点作斜率为 `k` 的直线族, 只要 `k` 取遍全体有理数 (及 `+-oo`), 直线族与曲线的交点就确定了曲线上的全体有理点. 换言之, 令 `k = p//q`, 则上述不定方程的通解可由 `p, q` 参数化, 形如 `x = x(p, q)`, `quad y = y(p, q)`, `quad z = z(p, q)`.
[来自 レイ] 证明: 单位圆上存在无数个点, 它们两两间的距离均为有理数.
[来自 折棒的网友] 记 `A(-1, 0)`, `B(1, 0)`. 对于任一组勾股数 `a^2+b^2=c^2`, 可取点 `K` 使得 `KA = 2a//c`, `KB = 2b//c`, 于是 `KA^2 + KB^2 = AB^2`, `K` 位于单位圆上. 依此法取 `K_1, K_2`, 则 `A B K_1 K_2` 是圆内接四边形, 由 Ptolemy 定理 `K_1 K_2 * AB + B K_1 * A K_2 = A K_1 * B K_2`. 因此 `K_1 K_2` 为有理数. 但勾股数有无穷多组, 所以这样的点有无穷多个.
[来自群友 我是绝妙的解析数论] 解不定方程 `1/a + 1/c = 2/b`.
[来自群友 问情明心]
方程化为 `b c + b a = 2a c`, 这是齐次方程. 和勾股数一样, 我们有两个观察:
一是只需求出本原解 `gcd(a,b,c) = 1`, 二是可以转化为曲线上的有理数解.
令 `a//b = x`, `c//b = y`, 问题化为求解曲线 `x + y = 2 x y` 上的有理点.
注意原点就是一个有理点, 取过原点的直线族 `y = k x`, `k` 是有理数. 则直线与曲线的交点是有理点;
反之曲线上的任一个有理点与原点连线的斜率是有理数. 从而只要 `k`
取遍全体有理数, 就得到曲线上的全体有理点.
令 `k = p//q` 为最简分数, 解得
`a//b = x = (1+k)/(2k)` `= (p+q)/(2p)`,
`c//b = y = (1+k)/2` `= (p+q)/(2q)`.
通分得到
`b = 2 p q`, `quad a = q(p+q)`, `quad c = p(p+q)`.
不定方程 `2 x^2 + 3 y^2 = 4 z^2` 只有平凡解.
换元 `2z mapsto z`, 新方程 `2 x^2 + 3 y^2 - z^2 = 0` 满足 `a b c` 无平方因子, `a, b, c` 不同号, 但 `-a c = 2` 不是模 `b = 3` 的二次剩余, 因此由 Legendre 定理知道新方程只有平凡解, 从而原方程也是如此.
不存在面积为平方数的勾股三角形.
Fermat 大定理 (Fermat's Last Theorem, FLT) 设整数 `n gt 2`, 则不定方程 `x^n + y^n = z^n` 不存在满足 `x, y, z != 0` 的整数解.
`133^5 + 110^5 + 84^5 + 27^5 = 144^5`
二平方和恒等式 `(x_1^2+x_2^2)(y_1^2+y_2^2) = (x_1 y_1+x_2 y_2)^2 + (x_1 y_2-x_2 y_1)^2`. 从而, 如果整数 `m, n` 能表示为两个整数的平方之和, 则 `mn` 也能.
素数 `p` 能表为两个整数的平方和当且仅当 `p = 2` 或 `p -= 1 (mod 4)`. 换言之, `4k+3` 型的素数不能表示为两个整数的平方和.
二平方和定理 正整数 `n` 能表为两个整数的平方和当且仅当它所有的 `4k+3` 型素因子在 `n` 中的次数为偶数.
三平方和定理 正整数 `n` 不能写为 3 个整数的平方和当且仅当存在非负整数 `a, b` 使得 `n = 4^a(8b+7)`.
本节将证明, 任意正整数可以表为四个整数的平方和. 其证明思路与二平方和定理类似.
Lagrange 恒等式 设 `n in ZZ^+`, `x_i, y_i in RR`, `i = 1, 2, cdots, n`, 则 `(sum_(i=1)^n x_i^2)(sum_(i=1)^n y_i^2)` `= (sum_(i=1)^n x_i y_i)^2 + sum_(1 le i lt j le n) (x_i y_j - x_j y_i)^2`. 从向量的角度理解: `|bm x|^2 |bm y|^2 = |bm x * bm y|^2 + |bm x xx bm y|^2`.
右边 `= sum_(i=1)^n x_i^2 y_i^2 + 2 sum_(1 le i lt j le n) x_i y_i x_j y_j + sum_(1 le i lt j le n) x_i^2 y_j^2` `- 2 sum_(1 le i lt j le n) x_i y_j x_j y_i + sum_(1 le i lt j le n) x_j^2 y_i^2` `= sum_(i=1)^n x_i^2 y_i^2 + sum_(1 le i lt j le n) x_i^2 y_j^2 + sum_(1 le i lt j le n) x_j^2 y_i^2 =`左边.
四平方和恒等式 (Euler, 1743)
`(sum_(i=1)^4 x_i^2)(sum_(i=1)^4 y_i^2) = sum_(i=1)^4 z_i^2`.
其中
`z_1 = x_1 y_1 + x_2 y_2 + x_3 y_3 + x_4 y_4`,
`z_2 = x_1 y_2 - x_2 y_1 + x_3 y_4 - x_4 y_3`,
`z_3 = x_1 y_3 - x_3 y_1 + x_4 y_2 - x_2 y_4`,
`z_4 = x_1 y_4 - x_4 y_1 + x_2 y_3 - x_3 y_2`.
从而, 如果整数 `m, n` 能表示为四个整数的平方之和,
则 `mn` 也能.
由 Lagrange 恒等式, 只需验证 `(x_1 y_2 - x_2 y_1)(x_3 y_4 - x_4 y_3)` `- (x_1 y_3 - x_3 y_1)(x_2 y_4 - x_4 y_2)` `+ (x_1 y_4 - x_4 y_2)(x_2 y_3 - x_3 y_2) = 0`. 即可. 上式的左边可由 Laplace 定理展开行列式 `|x_1,x_2,x_3,x_4; y_1,y_2,y_3,y_4; x_1,x_2,x_3,x_4; y_1,y_2,y_3,y_4|` 得到.
如果令 `bm x, bm y, bm z` 表示四元数
`bm x = x_1 - x_2 bb i + x_3 bb j - x_4 bb k`,
`bm y = y_1 + y_2 bb i - y_3 bb j + y_4 bb k`,
`bm z = z_1 + z_2 bb i - z_3 bb j + z_4 bb k`,
则
`bm x bm y = x_1 y_1 + x_2 y_2 + x_3 y_3 + x_4 y_4`
`+ (x_1 y_2 - x_2 y_1 + x_3 y_4 - x_4 y_3) bm i`
`- (x_1 y_3 - x_3 y_1 + x_4 y_2 - x_2 y_4) bm j`
`+ (x_1 y_4 - x_4 y_1 + x_2 y_3 - x_3 y_2) bm k`
`= bm z`.
因此四平方和恒等式可以简记为 `|bm x| |bm y| = |bm x bm y|`.
(Euler, 1751) 对任意奇素数 `p`, 同余方程 `x^2+y^2+1 = 0` `(mod p)` 存在整数解 `0 le x, y lt p//2`. 因此对任意奇素数 `p`, 存在正整数 `m` 和整数 `0 le x, y le (p-1)//2`, 使得 `m p = x^2 + y^2 + 1 le (p-1)^2//2 + 1` `lt (p-1)(p+1) + 1 = p^2`. 因此 `m lt p`.
模 `p` 的二次剩余 (即全体平方数 `ZZ^2` 模 `p` 的同余类)
有 `(p+1)//2` 个, 分别为
`0, 1^2, 2^2, cdots, ((p-1)/2)^2`.
若 `(p-1)//2` 是模 `p` 的二次剩余, 则存在 `0 le x lt p//2`
使得 `x^2 -= (p-1)//2` `(mod p)`, 于是 `1 + x^2 + x^2 -= 0` `(mod p)`,
定理得证.
若 `(p-1)//2` 不属于模 `p` 的二次剩余,
将模 `p` 的剩余 (即全体整数模 `p` 的同余类)
分为如下 `(p-1)//2` 组:
`{0, p-1}, {1, p-2}, cdots, {(p-1)/2, (p-1)/2}`.
而模 `p` 的 `(p+1)//2` 个二次剩余必然落在前 `(p-3)//2` 组当中.
由鸽巢原理, 必有两个二次剩余落在同一组中. 由于每一组的两个元素
`m, n` 满足 `m + n + 1 -= 0` `(mod p)`,
故存在整数 `x, y`, `0 le x, y lt p/2`,
使 `x^2 + y^2 + 1 -= 0` `(mod p)`.
四平方和定理 (Lagrange, 1770; Euler, 1773) 任何非负整数都可以表示为四个整数的平方之和, 即不定方程 `x_1^2 + x_2^2 + x_3^2 + x_4^2 = n`, `quad n ge 0` 恒有整数解.
说明: 将正整数分解为 4 个整数的平方和, 结果不唯一, 这里只给出一个解. 使用最朴素的暴力方法, 对于大素数性能较差.
[来自 Brilliant] 我们给出 Gauss 对于 `n = 3` 情形的证明. 对任意正整数 `a`, 由三平方和定理知道, `8a+3` 可以写成 3 个整数的平方和: `x_1^2 + x_2^2 + x_3^2 = 8a+3`. 由于对任意整数 `x`, `x^2` 模 8 的余数只能是 0, 1 或 4, 所以由上式知道 `x_i -= 1 (mod 8)`, `i = 1, 2 , 3`, 即 `x_1, x_2, x_3` 都是奇数. 令 `x_1 = 2x+1`, `x_2 = 2y+1`, `x_3 = 2z+1`, 有: `(2x+1)^2 + (2y+1)^2 + (2z+1)^2 = 8a+3`, 变形得到 `(x(x+1))/2 + (y(y+1))/2 + (z(z+1))/2 = a`.
设 `d` 为正整数, 且不是平方数, 下面的不定方程称为 Pell 方程: `x^2 - d y^2 = 1`.
Pell 方程的幂形式解 将 Pell 方程的全部正整数解 `x_k, y_k` (后面会证明 Pell 方程确实有解) 按 `lambda_k = x_k + sqrt d y_k` 的值由小到大排列, 有 `lambda_k = lambda_1^k`, `quad k = 1, 2, cdots`. 因此, 由 Pell 方程的最小正整数解 `x_1, y_1` 可以轻松得到通解.
设 `d in ZZ^+` 不是平方数, 若不定方程 `x^2 - d y^2 = n` 有最小正整数解 `x_0, y_0`, 则通解 `mu = x + sqrt d y` 由下式给出: `mu_k = mu_0 lambda_1^k`, `quad k = 0, 1, 2, cdots`. 其中 `lambda_1` 对应 Pell 方程 `x^2 - d y^2 = 1` 的最小正整数解.
化简 `root 3 (20+14sqrt2)`.
记 `lambda = x + y sqrt2`, 其共轭 `lambda' = x - y sqrt2`. 如果 `lambda^3 = 20+14 sqrt2`, 则有 `(x^2 - 2 y^2)^3` `= (lambda lambda')^3` `= lambda^3 (lambda^3)'` `= (20 + 14 sqrt2)(20-14 sqrt2) = 2^3`. 解不定方程 `x^2 - 2 y^2 = 2`, 得到最小正整数解 `x = 2`, `y = 1`, 发现恰有 `root 3 (20+14sqrt2) = 2 + sqrt 2`.
若 `d` 是正整数且不是平方数, 不定方程 `x^2 - d y^2 = n^k` 有正整数解 `x_k, y_k`, 问 `x^2 - d y^2 = n` 是否有正整数解 `x_1, y_1`, 使得 `(x_1 + sqrt d y_1)^k = x_k + sqrt d y_k` ?
我们来说明 Pell 方程确实有解.
`x^2 - d y^2 = 1` | `x^2 - d y^2 = -1` | |
`n` 为偶数 | `j = 1, 2, 3, ...` | 无解 |
`n` 为奇数 | `j = 2, 4, 6, ...` | `j = 1, 3, 5, ...` |
三角数中有无穷多个平方数, 换言之方程 `x^2 = y(y+1)//2` 有无穷多整数解.
`y` 与 `y+1` 互素, 而乘积是平方数的两倍, 因此它们一个是平方数 `u^2`, 另一个是平方数的两倍 `2v^2`, 其中 `u v = x`. 当 `y` 是偶数时, `y = 2v^2`, `y+1 = u^2`, 对应 Pell 方程 `u^2 - 2v^2 = 1`, 它有无穷多整数解. 当 `y` 是奇数时, 同理对应 Pell 方程 `u^2 - 2 v^2 = -1` 的解.
[来自 Elliptic Curve Cryptography: a gentle introduction, 加藤和也等《数论I: Fermat 的梦想和类域论》]
域 `K` (特征 `ne 2`) 上的椭圆曲线是指方程 `y^2 = x^3 + a x + b`, `quad a, b in K`, 且等号右边的 `x^3 + a x + b` 无重根.
一般而言, 椭圆曲线上的整点只有有限个 (Siegel 定理), 但有理点可能为无限个, 也可能为有限个.
考虑椭圆曲线 `y^2 = x^3 - x = x(x+1)(x-1)`, 它有 3 个明显的有理点 `P_0(0, 0)`, `P_1(1, 0)`, `P_2(-1, 0)`. 假设 `Q(x, y)` 也是曲线上的有理点, 求 `P_0 + Q`, `P_1 + Q` 和 `2Q`.
# 椭圆曲线群的加法 def add(x0, y0, x1, y1, y, expr): k = (y1-y0)/(x1-x0) if x1 != x0 else diff(expr**2)/(2*y) x_res = expand(k**2-x0-x1).replace(y, expr).simplify() y_res = expand(-y0-k*(x_res-x0)).replace(y, expr).simplify() return x_res, y_res add(0, 0, x, y, y, sqrt(x**3-x)) # (-1/x, sqrt(x**3 - x)/x**2) add(1, 0, x, y, y, sqrt(x**3-x)) # ((x + 1)/(x - 1), -2*sqrt(x**3 - x)/(x**2 - 2*x + 1)) add(x, y, x, y, y, sqrt(x**3-x)) # ((x**4 + 2*x**2 + 1)/(4*x*(x**2 - 1)), (x**6 - 5*x**4 - 5*x**2 + 1)/(8*x*sqrt(x*(x**2 - 1))*(x**2 - 1)))
z = u*v+v*w+w*u y = (u+v)*(v+w)*(w+u) expand((u**2+z)*(v**2+z)*(w**2+z)-y**2) # 0验证逆映射:
u = ((x-d)**2-2*d**2)/(2*y) v = (x**2+d**2)/(2*y) w = ((x+d)**2-2*d**2)/(2*y) simp = lambda e: expand(e).replace(d, sqrt((x**3-y**2)/x)).simplify() simp((u+v)*(v+w)) # x simp((u+v)*(v+w)*(w+u)) # y验证等差数列:
simp(v**2-u**2-d) # 0 simp(v**2-w**2+d) # 0
证明过程中用到的映射
`g(x, y) = 1/(2y)((x-d)^2 - 2d^2, x^2+d^2, (x+d)^2 - 2d^2)`,
`h(u, v, w) = (v^2, u v w)`,
它们的复合 `h@g` 恰好是椭圆曲线上的 2 倍映射, 即 `P mapsto 2P`:
`h@g(x, y) = ((x^2+d^2)^2/(4y^2), (((x-d)^2-2d^2)(x^2+d^2)((x+d)^2-2d^2))/(8y^3))`.
直角三角形 `(a, b, c) = (3, 4, 5)` 的面积为 `d = 6`, 对应椭圆曲线 `y^2 = x^3 - d^2 x = x^3 - 36x` 的有理点 `(18, 72)`. 通过 2 倍映射, 可以再构造一个面积为 6 的直角三角形: `((2a b c)/(b^2-a^2), (b^2-a^2)/(2c), (c^4+4a^2 b^2)/(2c(b^2-a^2)))` `= (120/7, 7/10, 1201/70)`.
# 推导构造直角三角形的公式 d = a*b/2 u, v, w = (b-a)/2, c/2, (a+b)/2 x, y = v**2, u*v*w uu = ((x-d)**2 - 2*d**2)/(2*y) vv = (x**2+d**2)/(2*y) ww = ((x+d)**2 - 2*d**2)/(2*y) aa, bb, cc = ww-uu, ww+uu, vv*2 simplify(aa) # -2*a*b*c/(a**2 - b**2) simplify(bb).replace(c, sqrt(a**2+b**2)).simplify() # (-a**2 + b**2)/(2*sqrt(a**2 + b**2)) simplify(cc) # (-4*a**2*b**2 - c**4)/(2*c*(a - b)*(a + b))
[来自 知乎专栏]
求这个不定方程的正整数解:
`(🍎)/(🍌+🍍) + (🍌)/(🍍+🍎) + (🍍)/(🍎+🍌) = 4`,
`(a)/(b+c) + (b)/(c+a) + (c)/(a+b) = 4`.
from fractions import Fraction from math import lcm def add(x0, y0, x1, y1, args): if y0 is None: return x1, y1 if y1 is None: return x0, y0 if x0 == x1 and y0 != y1: return None, None k = Fraction(y1-y0, x1-x0) if x1 != x0 else Fraction(3*x0**2 + 2*args[2]*x0 + args[1], 2*y0) x_res = k**2-args[2]-x0-x1 y_res = -y0-k*(x_res-x0) return x_res, y_res p = (-100, 260) q = (-100, 260) a, b, c = (4, -1, 11) args = (0, 224, 109) n = 1 while not ((a < 0 and b < 0 and c < 0) or (a > 0 and b > 0 and c > 0)): n += 1 q = add(*p, *q, args) x, y = q print(f'{n}P = ({x}, {y})') a, b, c = Fraction(56-x+y, 56-14*x), Fraction(56-x-y, 56-14*x), Fraction(-28-6*x, 28-7*x) d = lcm(a.denominator, b.denominator, c.denominator) print(f'a = {a * d}\nb = {b * d}\nc = {c * d}')当我们计算到 `9P` 时, 找到了第一组正有理数解, 将它适当通分即得到正整数解:
2P = (8836/25, -950716/125) 3P = (-731025/11881, 527529870/1295029) 4P = (561561391876/8356702225, -687837762272090924/763927933898375) 5P = (-425869857827702500/15192076294211881, 448412887098983162164732300/1872516697802137088411221) 6P = (252785840525963937198721/13225347684085115955600, -343764653760831645784970282294394569/1520934975898868459000385442296000) 7P = (-1872773018543093075805479817148900/163350615997049698719631653803161, 211390151297491981533823798000243842339853402161620/2087762847145230771938050768331341412318712353341) 8P = (8304830821343520148948729081523501917420036/1462178082526064533227321540886890051021025, -124668752376211382766812793520103329799089543359986485854396841484/1768073864797815348625142542347514156118825216532230801892732625) 9P = (-66202368404229585264842409883878874707453676645038225/13514400292716288512070907945002943352692578000406921, 58800835157308083307376751727347181330085672850296730351871748713307988700611210/1571068668597978434556364707291896268838086945430031322196754390420280407346469) a = 154476802108746166441951315019919837485664325669565431700026634898253202035277999 b = 36875131794129999827197811565225474825492979968971970996283137471637224634055579 c = 4373612677928697257861252602371390152816537558161613618621437993378423467772036
Mordell 定理
`QQ` 上的椭圆曲线群 `E(QQ)` 是有限生成 Abel 群: 存在 `P_1, cdots, P_r in E(QQ)`,
使得任意 `P in E(QQ)` 都能表示为 `P_1, cdots, P_r` 的线性组合:
`P = sum k_i P_i`.
这个群的秩称为该椭圆曲线的秩.
又根据 Mazur[1977] 的结果, `E(QQ)` 的挠子群 (有限阶元素组成的子群)
在同构意义下只有以下几种:
`ZZ//n ZZ`, `quad 1 le n le 10 or n = 12`.
`ZZ/n ZZ o+ Z//2 ZZ`, `quad n = 2, 4, 6, 8`.
椭圆曲线上的离散对数问题 设 `p` 为奇素数, 考虑有限域 `bbb F_p` 中的椭圆曲线, 它的加法群定义与 `QQ` 上的完全相同, 只不过运算是模 `p` 的. 一个计算困难的问题是: 已知两点 `P, Q`, 求 `k` 使得 `Q = k P`. 这称为椭圆曲线上的离散对数问题, 也是许多加密算法的基础.
Schoof 算法 可在多项式时间内求椭圆曲线群 `G` 的阶.
知道了群 `G` 的阶后, 元素 `P` 的阶就是 `G` 的因子中使得 `k P = 0`
成立的最小 `k`.
给定素数 `q`, 可按如下方法在 `G` 中找一个 `q` 阶元:
计算 `|G| // q = h`, 然后任取 `P in G`, 则 `q(h P) = |G| P = 0`,
这指出 `h P` 的阶是 `q` 的因子, 但 `q` 为素数, 所以 `h P = 0` 或 `|h P| =
q`.
解关于 `x, y` 的不定方程 `a x y+b x+c y+d = 0`, `a, b, c, d` 为整数.
两边同乘 `a` 以后变形为 `(a x+c)(a y+b) = b c-a d`, 再讨论 `b c-a d` 的因子即可.
解关于 `a, b, c, d` 的不定方程 `1/a + 1/b + 1/c + 1/d = 1`, `a, b, c, d` 是两两不相等的正整数.
解关于 `x, y` 的不定方程 `x^2 + 615 = 2^y`.
[来自 我是小学二年级的屑] 求 `{ x y = 4 n; x+y = n+2 :}` 的正整数解.
求 `(x+y)^2 = x^3 + y^3` 的正整数解.
两边同时约去正因子 `x+y` 得
`x+y = x^2 - x y + y^2`,
这是椭圆的方程, 由图像我们推测正整数解只有 `(1,2)`, `(2,1)`, `(2,2)`.
[来自 我是费马方程的正整数解]
上式视为 `x` 的方程, 令它的判别式 `ge 0`, 我们得到 `y = 1, 2`,
从而轻松得到结果.
求 `x^3 + y^3 = z^2` 的正整数解.
令 `(x, y, z) = (a c, b c, c^2)`, 问题化为 `a^3 c^3 + b^3 c^3 = c^4`, 显然 `c != 0`, 得 `a^3 + b^3 = c`. 任取 `a, b in ZZ^+`, `(x, y, z) = (a (a^3+b^3), b (a^3+b^3), (a^3+b^3)^2)` 都给出原方程的一组正整数解; 如 `a=1, b=1` 时得到 `(2, 2, 4)`, `a=1, b=2` 时得到 `(9, 18, 81)` 等. 其它形式的解??
[来自 马上开学的菜狗] 求 `x^3 + y^3 = x^2 y^2` 的正整数解.
[来自 小猿搜题] 取参数 `t = x // y`, 方程化为 `(t^3+1) y^3 = t^2 y^4`, 从而 `{ x = t^2 + 1//t; y = t + 1//t^2 :}` `t = 1` 时, 得到一组解 `x = y = 2`. `t gt 1` 时, ??
[来自 叉叉子] 证明不定方程 `2x^4 = y^4 - 17 z^4` 只有平凡解 `x = y = z = 0`.
由于方程齐次, 不妨令 `gcd(x, y, z) = 1`, 考虑 mod 17 的可能余数: `{: 2x^4, y^4, 17z^4; 0, 0, 0; +-2, +-1, ; +-8, +-4, ; :}` 等式不能成立, 一个矛盾.
[来自 IMO1988 | 出题人 Stephan Beck] 设非负整数 `a, b` 使得 `(a^2+b^2)/(1+a b)` 为整数. 求证: 这个整数必是某一整数的平方.
expand(x**3 + (x+3)**3 + (x+5)**3 + (x+6)**3 + (x+9)**3 + (x+10)**3 + (x+12)**3 + (x+15)**3 - (x+1)**3 - (x+2)**3 - (x+4)**3 - (x+7)**3 - (x+8)**3 - (x+11)**3 - (x+13)**3 - (x+14)**3)