经过一些实验和搜索,我想出了以下定义:
emcd' :: Integer -> Integer -> (Integer,Integer,Integer)
emcd' a 0 = (a, 1, 0)
emcd' a b =
let (g, t, s) = emcd' b r
in (g, s, t - (q * s))
where
(q, r) = divMod a b
- 这个表达背后的含义是什么
t - (q * s)
?
我试图手动评估它;即使我得到了正确的结果(1, -4, 15)
,我也看不出为什么该表达式返回t
.
有一种著名的计算方法s
和t
in as + bt = gcd(a, b)
。在寻找 gcd 的过程中,我得到了几个方程。
通过反转欧几里得算法中的步骤,可以找到这些整数a
和b
。那些得到的方程看起来像表达式t - (q * s)
;但是,我无法弄清楚确切的过程。