functiongcd(a, b) { return b ? gcd(b, a % b) : a; }
这种递归实现的欧几里得算法非常简洁且高效。它利用了数学上的一个性质:两个整数的最大公约数与它们的余数和较小数的最大公约数相同。即 gcd(a, b) = gcd(b, a % b)。
5、快速幂
functionfastPower(b, n) { if (n === 0) return1; const result = fastPower(b, Math.floor(n / 2)); return n % 2 === 0 ? result * result : b * result * result; }
用于高效地计算 b 的 n 次方。快速幂算法特别适用于计算大幂次的情况,因为它将幂次的计算复杂度从 O(n) 降低到 O(log n)。
6、并查集
intfind(int x){ x==parent[x]?:find(parent[x]); }
并查集(Union-Find)数据结构中的 find 函数的简洁实现。
递归查找:find 函数通过递归的方式查找元素 x 的根节点。递归会在元素与其父节点不同时,继续查找父节点的父节点,直到找到一个元素其父节点是它自己的元素,即根节点。
路径压缩:代码中的三元运算符 ?: 实现了路径压缩技术。当 x 不是其根节点时(即 x != parent[x]),find 函数会调用自身并传入 parent[x] 作为参数。在递归返回的过程中,每个节点的父节点指针都被更新为最终的根节点,这样可以减少后续查找操作的深度。