swc/bundler/tests/.cache/deno/a41e999c2223615484075b574cf34570a0c89864.ts

14 lines
334 B
TypeScript
Raw Normal View History

// Loaded from https://deno.land/x/god_crypto@v1.4.3/src/math.ts
export function power_mod(n: bigint, p: bigint, m: bigint): bigint {
if (p === 1n) return n;
if (p % 2n === 0n) {
const t = power_mod(n, p >> 1n, m);
return (t * t) % m;
} else {
const t = power_mod(n, p >> 1n, m);
return (t * t * n) % m;
}
}