mirror of
https://github.com/TheAlgorithms/JavaScript.git
synced 2025-07-19 18:13:44 +08:00

* chore: Switch to Node 20 + Vitest * chore: migrate to vitest mock functions * chore: code style (switch to prettier) * test: re-enable long-running test Seems the switch to Node 20 and Vitest has vastly improved the code's and / or the test's runtime! see #1193 * chore: code style * chore: fix failing tests * Updated Documentation in README.md * Update contribution guidelines to state usage of Prettier * fix: set prettier printWidth back to 80 * chore: apply updated code style automatically * fix: set prettier line endings to lf again * chore: apply updated code style automatically --------- Co-authored-by: github-actions <${GITHUB_ACTOR}@users.noreply.github.com> Co-authored-by: Lars Müller <34514239+appgurueu@users.noreply.github.com>
31 lines
738 B
JavaScript
31 lines
738 B
JavaScript
function euclideanGCDRecursive(first, second) {
|
|
/*
|
|
Calculates GCD of two numbers using Euclidean Recursive Algorithm
|
|
:param first: First number
|
|
:param second: Second number
|
|
:return: GCD of the numbers
|
|
*/
|
|
if (second === 0) {
|
|
return first
|
|
} else {
|
|
return euclideanGCDRecursive(second, first % second)
|
|
}
|
|
}
|
|
|
|
function euclideanGCDIterative(first, second) {
|
|
/*
|
|
Calculates GCD of two numbers using Euclidean Iterative Algorithm
|
|
:param first: First number
|
|
:param second: Second number
|
|
:return: GCD of the numbers
|
|
*/
|
|
while (second !== 0) {
|
|
const temp = second
|
|
second = first % second
|
|
first = temp
|
|
}
|
|
return first
|
|
}
|
|
|
|
export { euclideanGCDIterative, euclideanGCDRecursive }
|