Files
30-seconds-of-code/snippets/geometricProgression.md
2022-05-03 18:34:25 +03:00

30 lines
1.1 KiB
Markdown

---
title: Geometric progression
tags: math,algorithm
expertise: intermediate
cover: blog_images/book-chair.jpg
excerpt: Initializes an array containing the numbers in the specified geometric progression range.
firstSeen: 2018-01-03T09:36:23+02:00
lastUpdated: 2020-12-28T13:49:24+02:00
---
Initializes an array containing the numbers in the specified range where `start` and `end` are inclusive and the ratio between two terms is `step`.
Returns an error if `step` equals `1`.
- Use `Array.from()`, `Math.log()` and `Math.floor()` to create an array of the desired length, `Array.prototype.map()` to fill with the desired values in a range.
- Omit the second argument, `start`, to use a default value of `1`.
- Omit the third argument, `step`, to use a default value of `2`.
```js
const geometricProgression = (end, start = 1, step = 2) =>
Array.from({
length: Math.floor(Math.log(end / start) / Math.log(step)) + 1,
}).map((_, i) => start * step ** i);
```
```js
geometricProgression(256); // [1, 2, 4, 8, 16, 32, 64, 128, 256]
geometricProgression(256, 3); // [3, 6, 12, 24, 48, 96, 192]
geometricProgression(256, 1, 4); // [1, 4, 16, 64, 256]
```