mirror of
https://github.com/TheAlgorithms/JavaScript.git
synced 2025-07-05 16:26:47 +08:00
merge: Add the Collatz Conjecture (#1022)
* Create CollatzConjecture.js * Create CollatzConjecture.test.js * Update CollatzConjecture.js * Update CollatzConjecture.test.js * Rename CollatzConjecture.js to CollatzSequence.js * Update and rename CollatzConjecture.test.js to CollatzSequence.test.js * Update CollatzSequence.js * Update CollatzSequence.test.js * Update CollatzSequence.test.js * Fix styling errors * Add suggestion Co-authored-by: Rak Laptudirm <rak@laptudirm.com> * Update CollatzSequence.js * Update CollatzSequence.js * Update comments to match the Collatz Sequence * Update CollatzSequence.test.js Co-authored-by: Rak Laptudirm <rak@laptudirm.com>
This commit is contained in:
30
Maths/CollatzSequence.js
Normal file
30
Maths/CollatzSequence.js
Normal file
@ -0,0 +1,30 @@
|
||||
/**
|
||||
* @function collatz
|
||||
* @description Applies the Collatz Sequence on a specified number.
|
||||
* The Collatz Sequence states that every natural number will always fall in a 1, 2, 4 loop when iterated under the following function:
|
||||
* If the number is even, divide by 2, and if its odd, multiply it by 3 and add 1.
|
||||
*
|
||||
* @parama {Integer} n The number to apply the Collatz Sequence to.
|
||||
*
|
||||
* @return An array of steps and the final result..
|
||||
*
|
||||
* @see [Collatz Conjecture](https://en.wikipedia.org/wiki/Collatz_conjecture)
|
||||
*
|
||||
* @example collatz(1) = { result: 1, steps: [] }
|
||||
* @example collatz(5) = { result: 1, steps: [16, 8, 4, 2, 1] }
|
||||
*/
|
||||
export function collatz (n) {
|
||||
const steps = []
|
||||
|
||||
while (n !== 1) {
|
||||
if (n % 2 === 0) {
|
||||
n = n / 2
|
||||
} else {
|
||||
n = 3 * n + 1
|
||||
}
|
||||
|
||||
steps.push(n)
|
||||
}
|
||||
|
||||
return { result: n, steps: steps }
|
||||
}
|
8
Maths/test/CollatzSequence.test.js
Normal file
8
Maths/test/CollatzSequence.test.js
Normal file
@ -0,0 +1,8 @@
|
||||
import { collatz } from '../CollatzSequence'
|
||||
|
||||
describe('The Collatz Sequence', () => {
|
||||
it('Should be 1', () => {
|
||||
expect(collatz(1)).toStrictEqual({ result: 1, steps: [] })
|
||||
expect(collatz(5)).toStrictEqual({ result: 1, steps: [16, 8, 4, 2, 1] })
|
||||
})
|
||||
})
|
Reference in New Issue
Block a user